## MC68HC916X1

## Technical Summary 16-Bit Modular Microcontroller

## 1 Introduction

The MC68HC916X1 microcontroller (MCU) is a high-speed 16-bit device that is upwardly code compatible with M68HC11 controllers. It is a member of the M68300/68HC16 Family of modular microcontrollers.

M68HC16 controllers are built up from standard modules that interface via a common intermodule bus (IMB). Standardization facilitates rapid development of devices tailored for specific applications.

The MC68HC916X1 incorporates a true 16-bit CPU (CPU16), a single-chip integration module (SCIM), an 8/10-bit analog-to-digital converter (ADC), a queued serial module (QSM), a generalpurpose timer (GPT), 2 Kbytes of standby RAM (SRAM), 48 Kbytes of flash EEPROM (FLASH), and 2 Kbytes of block-erasable flash EEPROM (BEFLASH). These modules are interconnected by the intermodule bus (IMB).

The maximum system clock for the MC68HC916X1 is 16.78 MHz . A phase-locked loop circuit synthesizes the clock from a frequency reference. Either a crystal with a nominal frequency of 4.194 MHz or an externally generated signal can be used. System hardware and software support changes in the clock rate during operation. Because the MC68HC916X1 is a fully static design, register and memory contents are not affected by clock rate changes.

High-density complementary metal-oxide semiconductor (HCMOS) architecture makes the basic power consumption of the MC68HC916X1 low. Power consumption can be minimized by stopping the system clock. The M68HC16 instruction set includes a low-power stop (LPSTOP) command that efficiently implements this capability.

Table 1 Ordering Information

| Package Type | Frequency | Temperature | Package Order <br> Quantity | Order Number |
| :---: | :---: | :---: | :---: | :---: |
| 120 QFP | 16.78 MHz | -40 to $+85^{\circ} \mathrm{C}$ | 250 | MC916X1CTH16B1 |
|  |  |  | 50 | MC68HC916X1CTH16 |
|  |  |  | 2 | SPMC916X1CTH16 |

Section Page
1 Introduction ..... 1
1.1 Features ..... 4
1.2 Block Diagram ..... 5
1.3 Pin Assignments ..... 6
1.4 Address Map ..... 6
1.5 Intermodule Bus ..... 7
2 Signal Descriptions ..... 8
2.1 Pin Characteristics ..... 8
2.2 MCU Power Connections ..... 9
2.3 MCU Output Driver Types ..... 9
2.4 MCU Signal Characteristics ..... 10
2.5 MCU Signal Function ..... 11
3 Single-Chip Integration Module ..... 13
3.1 Overview ..... 13
3.2 System Configuration ..... 15
3.3 System Clock ..... 20
3.4 System Protection ..... 25
3.5 External Bus Interface ..... 28
3.6 Bus Control Signals ..... 29
3.7 Resets ..... 32
3.8 Interrupts ..... 34
3.9 Chip Selects ..... 37
3.10 General-Purpose Input/Output ..... 45
3.11 Factory Test ..... 50
4 Central Processing Unit ..... 51
4.1 Overview ..... 51
4.2 M68HC11 Compatibility ..... 51
4.3 Programming Model ..... 52
4.4 Data Types ..... 53
4.5 Addressing Modes ..... 54
4.6 Instruction Set ..... 55
4.7 Exceptions ..... 75
5 Analog-to-Digital Converter Module ..... 78
5.1 Analog Subsystem ..... 78
5.2 Digital Control Subsystem ..... 78
5.3 Bus Interface Subsystem ..... 78
5.4 ADC Address Map ..... 80
5.5 ADC Registers ..... 81
6 General-Purpose Timer Module ..... 87
6.1 Overview ..... 87
6.2 GPT Address Map ..... 88
6.3 Capture/Compare Unit ..... 88
6.4 Pulse-Width Modulator ..... 91
6.5 GPT Registers ..... 93
$7 \quad$ Queued Serial Module ..... 100
7.1 Overview ..... 100
7.2 Pin Function ..... 101
7.3 QSM Registers ..... 102
7.4 QSPI Submodule ..... 105
7.5 SCI Submodule ..... 114
8 Standby RAM Module ..... 120
8.1 Overview ..... 120
8.2 SRAM Register Block ..... 120
8.3 SRAM Registers ..... 120
8.4 SRAM Operation ..... 122

## TABLE OF CONTENTS (Continued)

Section Page
9 Flash EEPROM Module ..... 123
9.1 Overview ..... 123
9.2 Address Map ..... 123
9.3 Flash EEPROM Control Block ..... 124
9.4 Flash EEPROM Array ..... 125
9.5 Flash EEPROM Registers ..... 125
9.6 Flash EEPROM Operation ..... 128
10 Block-Erasable Flash EEPROM ..... 133
10.1 Overview ..... 133
10.2 BEFLASH Control Block ..... 134
10.3 BEFLASH Array ..... 134
10.4 BEFLASH Registers ..... 134
10.5 BEFLASH Operation ..... 137
11 Electrical Characteristics ..... 140

### 1.1 Features

- CPU16
- 16-bit architecture
- Full set of 16-bit instructions
- Three 16-bit index registers
- Two 16-bit accumulators
- 16-bit multiply and accumulate (digital signal processing support)
- High-level language support
- Fast interrupt response time
- Hardware breakpoint signal/Background debugging mode
- Fully static implementation
- Single-Chip Integration Module (SCIM)
- Single-chip or expanded modes of operation
- External bus support in expanded mode
- Five programmable chip-select outputs
- Watchdog timer, clock monitor, and bus monitor
- Address and data bus provide 33 discrete I/O lines in single-chip mode
- Phase-locked loop (PLL) clock system
- 8/10-Bit Analog-to-Digital Converter (ADC)
- Six channels, eight result registers
- Eight automated modes
- Three result alignment formats
- Queued Serial Module (QSM)
- Enhanced serial communication interface (SCI)
- Queued serial peripheral interface (QSPI)
- Dual function I/O ports
- General-Purpose Timer (GPT)
- Two 16-bit free-running counters with prescaler
- Three input capture channels
- Four output compare channels
- One input capture/output compare channel
- One pulse accumulator/event counter input
- Two pulse-width modulation outputs
- Optional external clock input
- 2 Kbyte Standby RAM Module (SRAM)
- External standby voltage supply input for low-power standby operation
- Flash EEPROM (16 and 32 Kbyte modules)
- Bulk erase mode
- Can provide a contiguous 48 Kbyte address space
- 2 Kbyte Flash EEPROM with Independently Erasable Blocks (BEFLASH)
- Bulk/block erase and byte/word programming with 12 volt external input


### 1.2 Block Diagram



Figure 1 MC68HC916X1 Block Diagram

### 1.3 Pin Assignments



Figure $\mathbf{2}$ MC68HC916X1 Pin Assignments

### 1.4 Address Map

Figure $\mathbf{3}$ is a map of the MCU internal addresses. Although there are 24 IMB address lines, the CPU16 uses only ADDR[19:0]. ADDR[23:20] are driven to the same logic state as ADDR19. Addresses $\$ 080000$ to \$F7FFFF are not accessible. The 2-Kbyte SRAM, 16-Kbyte and 32-Kbyte flash EEPROM arrays are positioned by the base address registers in their respective control blocks. Reset disables the SRAM array. Unimplemented blocks are mapped externally.


Figure 3 MC68HC916X1 Address Map

In the address map, $\mathrm{Y}=\mathrm{M} 111$, where M reflects the state of the module mapping (MM) bit in the SCIM module configuration register (SCIMCR). On M68HC16 microcontrollers, Y must equal \$F. If $M$ equals 0 , IMB modules become inaccessible until a reset occurs. The SCIMCR MM bit can be written only once after reset.

### 1.5 Intermodule Bus

The IMB is a standardized bus developed to facilitate design of modular microcontrollers. It contains circuitry that supports exception processing, address space partitioning, multiple interrupt levels, and vectored interrupts. The standardized modules in the MCU communicate with one another and with external components via the IMB. Although the full IMB supports 24 address and 16 data lines, this MCU uses only 20 address lines. Because the CPU16 uses only 20 address lines, ADDR[23:20] follow the state of ADDR19.

## 2 Signal Descriptions

### 2.1 Pin Characteristics

Table 2 shows MCU pins and their characteristics. All inputs detect CMOS logic levels. All inputs can be put in a high-impedance state, but the method of doing this differs depending upon pin function. Refer to Table 4 for a description of output drivers. An entry in the discrete I/O column of the MCU pin characteristics table indicates that a pin has an alternate I/O function. The port designation is given when it applies. Refer to Figure 1 for information about port organization.

Table $\mathbf{2}$ MCU Pin Characteristics

| Pin Mnemonic | Output Driver | Input <br> Synchronized | Input Hysteresis | $\begin{gathered} \hline \text { Discrete } \\ \text { I/O } \end{gathered}$ | Port <br> Designation |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ADDR23/CS10/ECLK | A | Y | N | - | - |
| ADDR19/CS6 | A | Y | N | O | PC3 |
| ADDR[18:11] | A | Y | Y | I/O | PA[7:0] |
| ADDR[10:3] | A | Y | Y | I/O | PB[7:0] |
| ADDR[2:0] | A | - | - | - | - |
| AN[5:0] ${ }^{1}$ | - | Y | Y | 1 | PADA[5:0] |
| $\overline{\text { AS }}$ | B | Y | Y | I/O | PE5 |
| $\overline{\mathrm{BERR}}^{2}$ | B | Y | N | - | - |
| BG/CSM | B | - | - | - | - |
| BGACK/CSE | B | Y | N | - | - |
| BKPT/DSCLK | - | Y | N | - | - |
| BR/CSO | B | Y | N | - | - |
| CLKOUT | A | - | - | - | - |
| DATA[15:8] ${ }^{1}$ | Aw | Y | Y | I/O | PG[7:0] |
| DATA[7:0] ${ }^{1}$ | Aw | Y | Y | I/O | PH[7:0] |
| DS | B | Y | Y | I/O | PE4 |
| DSACK1 | B | Y | N | I/O | PE1 |
| EXTAL ${ }^{3}$ | - | - | - | - | - |
| FC[2:0]/CS5, $\overline{\mathrm{CS3}}$ | A | - | - | O | PC[2:0] |
| FREEZE/QUOT | A | - | - | - | - |
| IC4/OC5 | A | Y | Y | I/O | PGP7 |
| IC[3:1] | A | Y | Y | I/O | PGP[2:0] |
| IPIPE1/DSI | A | Y | Y | - | - |
| IPIPE0/DSO | A | - | - | - | - |
| IRQ[7:6] | B | Y | Y | I/O | PF[7:6] |
| MISO | Bo | Y | Y | I/O | PQS6 |
| MODCLK ${ }^{1}$ | B | Y | Y | I/O | PF0 |
| MOSI | Bo | Y | Y | I/O | PQS7 |
| OC[4:1] | A | Y | Y | I/O | PGP[6:3] |
| PAI ${ }^{4}$ | - | Y | Y | I | - |
| PCLK ${ }^{4}$ | - | Y | Y | I | - |
| PCS0/SS | Bo | Y | Y | I/O | PQS1 |
| PCS[3:1] | Bo | Y | Y | I/O | PQS[4:2] |
| PWMA, PWMB ${ }^{5}$ | A | Y | Y | 0 | - |
| R/W | A | - | - | - | - |

Table 2 MCU Pin Characteristics (Continued)

| Pin Mnemonic | Output <br> Driver | Input <br> Synchronized | Input <br> Hysteresis | Discrete <br> I/O | Port <br> Designation |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RESET | Bo | Y | Y | - | - |
| RXD | Bo | Y | Y | $\mathrm{I} / \mathrm{O}$ | - |
| SCK | Bo | Y | Y | $\mathrm{I} / \mathrm{O}$ | $\mathrm{PQS5}$ |
| SIZ[1:0] | B | Y | N | $\mathrm{I} / \mathrm{O}$ | $\mathrm{PE}[7: 6]$ |
| TSC | - | Y | Y | - | - |
| $\mathrm{TXD}^{\text {PFC }^{3}}$ | Bo | Y | Y | $\mathrm{I} / \mathrm{O}$ | $\mathrm{PQS0}$ |
| XTAL $^{3}$ | - | - | - | - | - |

1. DATA[15:0] are synchronized during reset only. MODCLK and ADC pins are synchronized only if used as input port pins.
2. BERR only synchronized if late BERR.
3. EXTAL, XFC, and XTAL are clock reference connections.
4. PAI and PCLK can be used for discrete input, but are not part of an I/O port.
5. PWMA and PWMB can be used for discrete output, but are not part of an I/O port.

### 2.2 MCU Power Connections

Table 3 MCU Power Connections

| Pin | Description |
| :---: | :---: |
| $\mathrm{V}_{\mathrm{DDA}} / \mathrm{V}_{\text {SSA }}$ | A/D converter power |
| $\mathrm{V}_{\text {SSSYN }}$ | Clock synthesizer power |
| $\mathrm{V}_{\text {DDE }}, \mathrm{V}_{\text {SSE }}$ | External periphery power (source and drain) |
| $\mathrm{V}_{\mathrm{DDI}}, \mathrm{V}_{\text {SSI }}$ | Internal module power (source and drain) |
| $\mathrm{V}_{\text {STBY }}$ | Standby RAM power/clock synthesizer power |
| $\mathrm{V}_{\text {FPE2K }}$ | 2K block erasable flash (shared with 16K flash EEPROM array) |
| program/erase power |  |

### 2.3 MCU Output Driver Types

Table 4 MCU Output Driver Types

| Type | I/O | Description |
| :---: | :---: | :--- |
| A | O | Output-only signals that are always driven; no external pull-up required. |
| Aw | O | Type A output with weak P-channel pull-up during reset. |
| B | O | Three-state output that includes circuitry to pull up output before high impedance is estab- <br> lished, to ensure rapid rise time. An external holding resistor is required to maintain logic level <br> while the pin is in the high-impedance state. |
| Bo | O | Type B output that can be operated in an open-drain mode. |

### 2.4 MCU Signal Characteristics

Table 5 MCU Signal Characteristics

| Signal Name | MCU Module | Signal Type | Active State |
| :---: | :---: | :---: | :---: |
| ADDR[19:0] | SCIM | Bus | - |
| AN[5:0] | ADC | Input | - |
| $\overline{\text { AS }}$ | SCIM | Output | 0 |
| BERR | SCIM | Input | 0 |
| $\overline{\mathrm{BG}}$ | SCIM | Output | 0 |
| BGACK | SCIM | Input | 0 |
| BKPT | CPU16 | Input | 0 |
| $\overline{\mathrm{BR}}$ | SCIM | Input | 0 |
| CLKOUT | SCIM | Output | - |
| $\overline{\text { CS10, }} \overline{\mathrm{CS}}[6: 5], \overline{\mathrm{CS3}}, \overline{\mathrm{CSO}}$ | SCIM | Output | 0 |
| CSE | SCIM | Output | 0 |
| $\overline{\text { CSM }}$ | SCIM | Output | 0 |
| DATA[15:0] | SCIM | Bus | - |
| $\overline{\text { DS }}$ | SCIM | Output | 0 |
| DSACK1 | SCIM | Input | 0 |
| DSCLK | CPU16 | Input | Serial Clock |
| DSI | CPU16 | Input | Serial Data |
| DSO | CPU16 | Output | Serial Data |
| ECLK | CPU16 | Output | - |
| EXTAL | CPU16 | Input | - |
| FREEZE | SCIM | Output | 1 |
| IC[4:1] | GPT | Input | - |
| IPIPE0 | CPU16 | Output | - |
| IPIPE1 | CPU16 | Output | - |
| $\overline{\text { RQ[7:6] }}$ | SCIM | Input | 0 |
| MISO | QSM | Input/Output | Serial Data |
| MODCLK | SCIM | Input | - |
| MOSI | QSM | Input/Output | Serial Data |
| OC[5:1] | GPT | Output | - |
| PAI | GPT | Input | - |
| PCLK | GPT | Input | - |
| PCS0/SS | QSM | Input | 0 |
| PCS[3:1] | QSM | Input | 0 |
| PWMA, PWMB | GPT | Output | - |
| QUOT | SCIM | Output | - |
| R/W | SCIM | Output | - |
| RESET | SCIM | Input/Output | 0 |
| RXD | QSM | Input | - |
| SCK | QSM | Input/Output | - |
| SIZ[1:0] | SCIM | Output | - |
| TSC | SCIM | Input | 1 |
| TXD | QSM | Input/Output | - |
| XFC | SCIM | Input | - |
| XTAL | SCIM | Output | - |

### 2.5 MCU Signal Function

Table 6 MCU Signal Function

| Signal Name | Mnemonic | Function |
| :---: | :---: | :---: |
| Address Bus | ADDR[19:0] | 20-bit address bus used by CPU16 |
| ADC Analog Input | AN[5:0] | Inputs to ADC multiplexer |
| Address Strobe | $\overline{\text { AS }}$ | Indicates that a valid address is on the address bus |
| Bus Grant | $\overline{\text { BG }}$ | Indicates that the MCU has relinquished the bus |
| Bus Grant Acknowledge | BGACK | Indicates that an external device has assumed bus mastership |
| Bus Error | BERR | Indicates that a bus error has occurred |
| Breakpoint | BKPT | Signals a hardware breakpoint to the CPU |
| Bus Request | $\overline{\mathrm{BR}}$ | Indicates that an external device requires bus mastership |
| System Clockout | CLKOUT | System clock output |
| Emulation Mode Chip-Selects | $\overline{\mathrm{CSE}}, \overline{\mathrm{CSM}}$ | $\overline{\text { CSE }}$ selects external emulation devices at internally-mapped addresses. It is used to emulate I/O ports. CSM has no function on the MC68HC916X1. It is driven high if the SCIM is configured for emulation mode. |
| Chip-Selects | $\begin{gathered} \hline \text { CS10, CS[6:5], } \\ \overline{\text { CS3, }} \mathrm{CS0} \end{gathered}$ | Select external devices at programmed addresses |
| Data Bus | DATA[15:0] | 16-bit data bus |
| Data Strobe | $\overline{\text { DS }}$ | During a read cycle, indicates that an external device should place valid data on the data bus. During a write cycle, indicates that valid data is on the data bus. |
| Data and Size Acknowledge | $\overline{\text { DSACK1 }}$ | Asserted by external devices during asynchronous transfers to indicate receipt of data and width of receiving port |
| Development Serial In, Out, Clock | DSI, DSO, DSCLK | Serial I/O and clock for background debug mode |
| External Clock | ECLK | M6800 bus clock output |
| Crystal Oscillator | EXTAL, XTAL | Connections for clock synthesizer circuit reference; a crystal or an external oscillator can be used |
| Function Codes | FC[2:0] | Identify processor state and current address space |
| Freeze | FREEZE | Indicates that the CPU16 has entered background mode |
| Instruction Pipeline | IPIPE[1:0] | Indicates instruction pipeline activity |
| Interrupt Request | IRQ[7:6] | Request interrupt service from the CPU16 |
| Master In Slave Out | MISO | Serial input to SPI in master mode; serial output from SPI in slave mode |
| Clock Mode Select | MODCLK | Selects the source and type of system clock |
| Master Out Slave In | MOSI | Serial output from SPI in master mode; serial input to SPI in slave mode |
| Peripheral Chip-Selects | PCS[3:0] | QSPI peripheral chip selects |
| Port A | PA[7:0] | Port A digital input or output signals |
| Port B | PB[7:0] | Port B digital input or output signals |
| Port C | PC[3:0] | Port C digital input/output port signals |
| Port E | PE1, PE[7:4] | Port E digital I/O port signals |
| Port F | PF0, PF[7:6] | Port F digital I/O port signals |
| Port G | PG[7:0] | Port G digital I/O signals |
| Port GP | PGP[7:0] | GPT digital I/O port signal |
| Port H | PH[7:0] | Port H digital I/O signal |
| Port QS | PQS[7:0] | QSM digital I/O port signal |
| Pulse Accumulator Input | PAI | Input to the GPT pulse accumulator |

Table 6 MCU Signal Function (Continued)

| Signal Name | Mnemonic | Function |
| :--- | :---: | :--- |
| Quotient Out | QUOT | Provides the quotient bit of the polynomial divider |
| Read/Write | R/ $\bar{W}$ | Indicates the direction of data transfer on the bus |
| Reset | RESET | System reset |
| Receive Data (SCI) | RXD | Serial input to the SCI |
| Serial Clock (QSPI) | SCK | Clock output from QSPI in master mode; <br> clock input to QSPI in slave mode |
| Size | SIZ[1:0] | Indicates the number of bytes to be transferred during a bus cycle |
| Slave Select | $\overline{\text { SS }}$ | Causes serial transmission when QSPI is in slave mode; <br> causes mode fault in master mode |
| Three-State Control | TSC | Places all output drivers in a high-impedance state |
| Transmit Data (SCI) | TXD | Serial output from the SCI |
| External Filter Capacitor | XFC | Connection for external phase-locked loop filter capacitor |

## 3 Single-Chip Integration Module

The single-chip integration module (SCIM) consists of six submodules that, with a minimum of external devices, control system startup, initialization, configuration, and the external bus. Figure 4 shows the SCIM block diagram.


Figure 4 Single-Chip Integration Module Block Diagram

### 3.1 Overview

The system configuration block controls MCU configuration and operating mode.
The system clock generates clock signals used by the SCIM, other IMB modules, and external devices. In addition, a periodic interrupt generator supports execution of time-critical control routines.

The system protection block provides bus and software watchdog monitors.
The chip-select block provides five general-purpose chip-select signals and two emulation-support chip-select signals. The general-purpose chip-select signals have associated base address registers and option registers.

The external bus interface handles the transfer of information between IMB modules and external address space.

The system test block incorporates hardware necessary for testing the MCU. It is used to perform factory tests, and its use in normal applications is not supported.

Table 7 shows the SCIM address map, which occupies 128 bytes. Unused registers within the 128byte address space return zeros when read.

Table 7 SCIM Address Map

| Address | $\mathbf{1 5}$ | $\mathbf{8}$ |  | $\mathbf{7}$ |
| :---: | :---: | :---: | :---: | :---: |
| \$YFFA00 |  |  |  |  |

Table 7 SCIM Address Map (Continued)

| Address | $\mathbf{1 5}$ |
| :--- | :---: |
| \$YFFA50 | $\mathbf{8}$ R |
| \$YFFA52 | RESERVED |
| \$YFFA54 | RESERVED |
| \$YFFA56 | RESERVED |
| \$YFFA58 | RESERVED |
| \$YFFA5A | CHIP-SELECT BASE 3 (CSBAR3) |
| \$YFFA5C | CHIP-SELECT OPTION 3 (CSOR3) |
| \$YFFA5E | RESERVED |
| \$YFFA60 | RESERVED |
| \$YFFA62 | CHIP-SELECT BASE 5 (CSBAR5) |
| \$YFFA64 | CHIP-SELECT OPTION 5 (CSOR5) |
| \$YFFA66 | CHIP-SELECT BASE 6 (CSBAR6) |
| \$YFFA68 | CHIP-SELECT OPTION 6 (CSOR6) |
| \$YFFA6A | CHIP-SELECT BASE 7 (CSBAR7) |
| \$YFFA6C | CHIP-SELECT BASE 8 (CSBAR8) |
| \$YFFA6E | CHIP-SELECT OPTION 8 (CSOR8) |
| \$YFFA70 | CHIP-SELECT BASE 9 (CSBAR9) |
| \$YFFA72 | CHIP-SELECT OPTION 9 (CSOR9) |
| \$YFFA74 | CHIP-SELECT BASE 10 (CSBAR10) |
| \$YFFA76 | CHIP-SELECT OPTION 10 (CSOR10) |
| \$YFFA78 | RESERVED |
| \$YFFA7A | RESERVED |
| \$YFFA7C | RESERVED |
| \$YFFA7E | RESERVED |

1. $Y=M 111$, where $M$ is the logic state of the module mapping (MM) bit in the SCIMCR.

### 3.2 System Configuration

The MCU can operate as a stand-alone device (single-chip mode), with a 20-bit external address bus and an 8-bit external data bus, or with a 20-bit external address bus and a 16-bit external data bus. SCIM pins can be configured for use as I/O ports or programmable chip select signals. Refer to 3.9 Chip Selects and 3.10 General-Purpose Input/Output for more information. System configuration is determined by setting bits in the SCIM configuration register (SCIMCR), and by asserting MCU pins during reset.


1. Reset state is mode-dependent. Refer to the following bit descriptions.
2. This bit is reserved for future use. Ensure that initialization software does not change its value (it should always read zero).

The module configuration register controls system configuration. It can be read or written at any time, except for the module mapping (MM) bit, which must remain set to one and can only be written once.

EXOFF - External Clock Off
$0=$ The CLKOUT pin is driven from an internal clock source.
$1=$ The CLKOUT pin is placed in a high-impedance state.
FRZSW - Freeze Software Watchdog Enable
$0=$ When FREEZE is asserted, the software watchdog continues to run.
$1=$ When FREEZE is asserted, the software watchdog is disabled.
FRZBM - Freeze Bus Monitor Enable
$0=$ When FREEZE is asserted, the bus monitor continues to operate.
$1=$ When FREEZE is asserted, the bus monitor is disabled.
CPUD - CPU Development Support Disable
$0=$ Instruction pipeline signals available on pins IPIPE0 and IPIPE1
1 = Pins IPIPE0 and IPIPE1 placed in high-impedance state unless a breakpoint occurs
CPUD is cleared to zero when the MCU is in an expanded mode, and set to one in single-chip mode.

## SHEN[1:0] — Show Cycle Enable

This field determines how the external bus is driven during internal transfer operations. A show cycle allows internal transfers to be monitored externally. Table 8 shows whether show cycle data is driven externally, and whether external bus arbitration can occur. To prevent bus conflict, external peripherals must not be enabled during show cycles.

Table 8 Show Cycle Enable Field

| SHEN | Action |
| :---: | :--- |
| 00 | Show cycles disabled, external arbitration enabled |
| 01 | Show cycles enabled, external arbitration disabled |
| 10 | Show cycles enabled, external arbitration enabled |
| 11 | Show cycles enabled, external arbitration enabled, <br> internal activity is halted by a bus grant |

SUPV — Supervisor/Unrestricted Data Space
This bit has no effect because the CPU16 always operates in the supervisor mode.
MM — Module Mapping
$0=$ Internal modules are addressed from \$7FF000 - \$7FFFFF.
1 = Internal modules are addressed from \$FFF000 - \$FFFFFF.
The logic state of MM determines the value of ADDR23 for IMB module addresses. Because ADDR[23:20] are driven to the same state as ADDR19, MM must be set to one. If MM is cleared, IMB modules are inaccessible. This bit can be written only once after reset.

ABD - Address Bus Disable
$0=$ Pins ADDR[2:0] operate normally.
1 = Pins ADDR[2:0] are disabled.
ABD is cleared to zero when the MCU is in an expanded mode, and set to one in single-chip mode. ABD can be written only once after reset.
$0=\mathrm{R} / \mathrm{W}$ signal operates normally
$1=R / \bar{W}$ signal placed in high-impedance state.
RWD is cleared to zero when the MCU is in an expanded mode, and set to one in single-chip mode. RWD can be written only once after reset.

IARB[3:0] — Interrupt Arbitration
Each module that can generate interrupts, including the SCIM, has an IARB field. Each IARB field can be assigned a value from $\$ 0$ to $\$ F$. During an interrupt acknowledge cycle, IARB permits arbitration among simultaneous interrupts of the same priority level. The reset value of the SCIM IARB field is $\$ F$. This prevents SCIM interrupts from being discarded. Initialization software must set the IARB field to a lower value if lower priority interrupts are to be arbitrated.

### 3.2.1 Operating Modes

During reset, the SCIM configures itself according to the states of the DATA[11:0], BERR, MODCLK, and BKPT pins. DATA[11:0] provide pin configuration information. BERR, MODCLK, and BKPT determine basic operation.

The SCIM can be configured to operate in one of three modes: 16 -bit expanded, 8 -bit expanded, and single chip. Operating mode is determined by the value of the DATA1 and BERR signals coming out of reset. Table 9 shows the basic configuration options.

Table 9 Basic Configuration Options

| Select Pin | Default Function <br> (Pin Left High) | Alternate Function <br> (Pin Pulled Low) |
| :---: | :---: | :---: |
| MODCLK | Synthesized System Clock | External System Clock |
| BKPT | Background Mode Disabled | Background Mode Enabled |
| BERR | Expanded Mode | Single-Chip Mode |
| DATA1 (if BERR $=$ 1) | 8-Bit Expanded Mode | 16-Bit Expanded Mode |

$\overline{B E R R}, \overline{B K P T}$, and MODCLK do not have internal pull-ups and must be driven to the desired state during reset.

Operating mode determines which address and data bus lines are used and which general-purpose I/O ports are available. Table 10 is a summary of bus and port configuration options.

Table 10 Bus and Port Configuration Options

| Mode | Address Bus | Data Bus | I/O Ports |
| :---: | :---: | :---: | :---: |
| 16-Bit Expanded | ADDR[18:3] | DATA[15:0] | - |
| 8-Bit Expanded | ADDR[18:3] | DATA[15:8] | DATA[7:0] = Port H |
| Single Chip | None | None | ADDR $[18: 111]=$ Port A |
|  |  |  | ADDR[10:3] = Port B |
|  |  |  | DATA[15:8] Port G |
|  |  |  | DATA[7:0] = Port H |

Many pins on the MC68HC916X1, including data and address bus pins, have multiple functions. Reset value for these pins depends on operating mode. In expanded mode, the values of DATA[11:0] during reset determine the function of these pins. The functions of some pins can be changed by writing to the appropriate pin assignment register. Data bus pins have internal pull-ups and must be pulled low to achieve the alternate configuration desired. The following tables contain a summary of pin configuration options for each operating mode.

### 3.2.2 16-Bit Expanded Mode

In 16-bit expanded mode, $(\overline{\operatorname{BERR}}=1$, DATA1 $=0)$ pins ADDR[18:3] and DATA[15:0] are configured as address and data pins, respectively. The alternate functions for these pins as ports A, B, G, and H are unavailable. Table 11 is a summary of pin function options for 16 -bit data bus operation.

Table 11 16-Bit Expanded Mode Reset Configuration

| Pin(s) Affected | Select Pin | Default Function (Pin Held High) | Alternate Function (Pin Held Low) |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{BR}} / \mathrm{CSO}$ $\mathrm{FC} / \mathrm{CS3} / \mathrm{PC0}$ $\mathrm{FC} 1 / \mathrm{PC} 1$ $\mathrm{FC} 2 / \mathrm{CS5} / \mathrm{PC} 2$ | DATA2 | $\begin{aligned} & \hline \overline{\mathrm{CS0}} \\ & \text { CS3 } \\ & \mathrm{FC} 1 \\ & \hline \mathrm{CS5} \\ & \hline \end{aligned}$ | BR FC0 FC1 FC2 |
| ADDR19/CS6/PC3 ADDR23/CS10/ECLK | DATA3 ${ }^{1}$ DATA7 ${ }^{1}$ | $\frac{\overline{\mathrm{CS6}}}{\mathrm{CS10}}$ | ADDR19 ADDR23 |
| $\overline{\text { DSACK1/PE1 }} \overline{\text { DS/PE4 }}$ $\overline{\text { AS/PE5 }}$ SIZO/PE6 SIZ1/PE7 | DATA8 | $\overline{\text { DSACK1 }}$ $\overline{\text { DS }}$ AS SIZ0 SIZ1 | $\begin{aligned} & \hline \text { PE1 } \\ & \text { PE4 } \\ & \text { PE5 } \\ & \text { PE6 } \\ & \text { PE7 } \end{aligned}$ |
| $\begin{gathered} \text { MODCLK/PFO } \\ \hline \text { IRQ[7:6]/PF[7:6] } \end{gathered}$ | DATA9 | $\begin{gathered} \text { MODCLK } \\ \text { IRQ[7:6] } \end{gathered}$ | $\begin{gathered} \text { PF0 } \\ \text { PF[7:6] } \end{gathered}$ |
| $\begin{gathered} \overline{\mathrm{BGACK} / \mathrm{CSE}} \\ \overline{\mathrm{BG} / \mathrm{CSM}} \end{gathered}$ | DATA10 | $\overline{\overline{B G A C K}} \overline{\overline{B G}}$ | $\frac{\overline{\operatorname{CSE}}^{2}}{\mathrm{CSM}^{3}}$ |
| Reserved | DATA11 ${ }^{4}$ | Normal Operation | Reserved |
| Emulation Mode (SCIM) | DATA10 | Disabled | Enabled |
| STOP Mode (BEFLASH) | DATA15 | Array Enabled ${ }^{5}$ | Array Disabled |

1. $\overline{\mathrm{CS}}[9: 7]$ outputs are not available on the MC68HC916X1. Corresponding pin assignment register fields (CSPA1[3:1]) are affected by the state of DATA[6:4] during reset.
2. $\overline{C S E}$ is enabled when DATA10 and DATA1 $=0$ during reset.
3. $\overline{\text { CSM }}$ is enabled when DATA13, DATA10 and DATA1 $=0$ during reset.
4. DATA11 must remain high during reset to ensure normal operation of MCU.
5. Driven to put BEFLASH in STOP mode. STOP mode disabled when DATA15 is held high and STOP shadow bit is cleared.

### 3.2.3 8-Bit Expanded Mode

In 8 -bit expanded mode ( $\overline{B E R R}=1$, DATA1 $=1$ ), pins DATA[7:0] are configured as an 8 -bit I/O port. Pins DATA[15:8] are configured as data pins. Pins ADDR[18:3] are configured as address pins. Emulator mode is always disabled. Table 12 is a summary of pin function selections for 8 -bit data bus operation.

Table 12 8-Bit Expanded Mode Reset Configuration

| Pin(s) Affected | Select Pin | Default Function (Pin Held High) | Alternate Function (Pin Held Low) |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{BR}} / \overline{\mathrm{CSO}}$ | N/A ${ }^{1}$ | $\overline{\text { CSO }}$ | $\overline{\text { CSO }}$ |
| FC0/CS3/PC0 |  | CS3 | CS3 |
| FC1/PC1 |  | FC1 | FC1 |
| FC2/ES5/PC2 |  | $\overline{\mathrm{CS5}}$ | $\overline{\text { CS5 }}$ |
| ADDR19/CS6/PC0 | N/A ${ }^{1}$ | CS6 | CS6 |
| ADDR23/CS10/ECLK |  | CS10 | CS10 |
| $\overline{\text { DSACK1/PE1 }}$ | DATA8 | $\overline{\text { DSACK1 }}$ | PE1 |
| $\overline{\mathrm{DS}} / \mathrm{PE} 4$ |  | $\overline{\text { DS }}$ | PE4 |
| AS/PE5 |  | $\overline{\text { AS }}$ | PE5 |
| SIZ0/PE6 |  | SIZO | PE6 |
| SIZ1/PE7 |  | SIZ1 | PE7 |
| MODCLK/PF0 | DATA9 | MODCLK | PF0 |
| IRQ[7:6]/PF[7:6] |  | IRQ[7:6] | PF[7:6] |
| BGACK/CSE BG/CSM | $\mathrm{N} / \mathrm{A}^{1}$ | $\overline{\text { BGACK }}$ $\overline{\mathrm{BG}}$ | $\overline{\text { BGACK }}$ <br> BG |

1. These pins have only one reset configuration in 8-bit expanded mode.

### 3.2.4 Single-Chip Mode

In single-chip mode, when $\overline{B E R R}=0$ during reset, ADDR[18:3] are configured as 8 -bit I/O ports (port A and port B) and DATA[15:0] are configured as 8 -bit I/O ports (port G and port H). There is no external data bus path. Expanded mode configuration options are not available: I/O ports A, B, $\mathrm{E}, \mathrm{F}, \mathrm{G}$, and H are always selected. $\bar{B} E R R$ can be tied low permanently to select single-chip mode. Table 13 is a summary of SCIM pin functions during single-chip operation.

Table 13 Single-Chip Mode Reset Configuration

| Pin(s) Affected | Function |
| :---: | :---: |
| ADDR[18:11] | PA[7:0] |
| ADDR[10:3] | PB[7:0] |
| BR/CS0 | $\overline{\text { CSO }}$ |
| $\begin{gathered} \mathrm{FC0} / \mathrm{CS3} / \mathrm{PC} 0 \\ \mathrm{FC} 1 / \mathrm{PC} 1 \\ \text { FC2/CS5 } / \mathrm{PC} 2 \\ \text { ADDR19/CS6/PC3 } \\ \hline \end{gathered}$ | PC[3:0] |
| ADDR23/CS10/ECLK | - |
| $\overline{\text { DSACK1/PE1 }} 1$ DS/PE4 $\overline{\text { AS/PE5 }}$ SIZO/PE6 SIZ1/PE7 | PE[7:4], PE1 |
| $\begin{aligned} & \hline \text { MODCLK/PFO } \\ & \text { IRQ[7:6]/PF[7:6] } \\ & \hline \end{aligned}$ | $\begin{gathered} \text { PF0 } \\ \text { PF[7:6] } \\ \hline \end{gathered}$ |
| DATA[15:8] | PG[7:0] |
| DATA[7:0] | PH[7:0] |
| $\overline{\mathrm{BGACK}, \overline{C S E}}$ $\overline{\mathrm{BG}} / \mathrm{CSM}$ | $\begin{gathered} \overline{\overline{B G A C K}} \overline{\overline{B G}} \end{gathered}$ |

### 3.2.5 Emulation Support

The SCIM contains logic that can be used to replace on-chip ports externally. The SCIM also contains special support logic that allows external emulation of internal ROM. This emulation support feature enables the development of a single-chip application in expanded mode.

Emulator mode is a special type of 16-bit expanded operation. It is entered by holding DATA10 low, $\overline{B E R R}$ high, and DATA1 low during reset. In emulator mode, all port $A, B, E, G$, and $H$ data and data direction registers and the port E pin assignment register are mapped externally. Port C data, port $F$ data and data direction registers, and port $F$ pin assignment register are accessible normally in emulator mode.

An emulator chip select (CSE) is asserted whenever any of the externally-mapped registers are addressed. The signal is asserted on the falling edge of $\overline{\mathrm{AS}}$. The SCIM does not respond to these accesses, allowing external logic, such as a port replacement unit (PRU) to respond. Accesses to externally mapped registers require three clock cycles.

External ROM emulation is enabled by holding DATA1, DATA10, and DATA13 low during reset (BERR must be held high during reset to enable the ROM module). While ROM emulation mode is enabled, memory chip select signal $\overline{\text { CSM }}$ is asserted whenever a valid access to an address assigned to the masked ROM array is made.

The ROM module does not acknowledge IMB accesses while in emulation mode. This causes the SCIM to run an external bus cycle for each access.

## NOTE

The MC68HC916X1 flash modules do not yet support the emulator mode. If ROM emulation is enabled, the CSM chip-select will be driven high at all times.

### 3.3 System Clock

The system clock provides timing signals for the IMB modules and for an external peripheral bus. Because the MCU is a fully static design, register and memory contents are not affected when the clock rate changes. System hardware and software support changes in clock rate during operation.

The system clock signal can be generated from one of two sources. An internal phase-locked loop (PLL) can synthesize the clock from a fast reference, or the clock signal can be input directly from an external frequency source. The fast reference is typically a 4.194 MHz crystal, but may be generated by sources other than a crystal. Keep these sources in mind while reading the rest of this section.

Figure 5 is a block diagram of the clock submodule.


16/32 PLL BLOCK 4M
Figure 5 System Clock Block Diagram

### 3.3.1 Clock Sources

The state of the clock mode (MODCLK) pin during reset determines the system clock source. When MODCLK is held high during reset, the clock synthesizer generates a clock signal from an external reference frequency. The clock synthesizer control register (SYNCR) determines operating frequency and mode of operation. When MODCLK is held low during reset, the clock synthesizer is disabled and an external system clock signal must be driven onto the EXTAL pin.

The input clock is referred to as $f_{\text {ref }}$, and can be either a crystal or an external clock source. The output of the clock system is referred to as $f_{\text {sys }}$. Ensure that $f_{\text {ref }}$ and $f_{\text {sys }}$ are within normal operating limits.

To generate a reference frequency using the internal oscillator, a reference crystal must be connected between the EXTAL and XTAL pins. Typically, a 4.194 MHz crystal is used, but the frequency may vary between 1 and 6 MHz . Figure 6 shows a recommended circuit.


* RESISTANCE AND CAPACITANCE BASED ON A TEST CIRCUIT CONSTRUCTED WITH A KDS041-18 4.194 MHz CRYSTAL. SPECIFIC COMPONENTS MUST BE BASED ON CRYSTAL TYPE. CONTACT CRYSTAL VENDOR FOR EXACT CIRCUIT.

Figure 6 System Clock Oscillator Circuit

If a fast reference frequency is provided to the PLL from a source other than a crystal, or an external system clock signal is applied through the EXTAL pin, the XTAL pin must be left floating.

When an external system clock signal is applied (MODCLK = 0 during reset), the PLL is disabled. The duty cycle of the input is critical, especially at operating frequencies close to maximum. The relationship between clock signal duty cycle and clock signal period is expressed as follows:

$$
\text { Minimum External Clock Period }=\frac{\text { Minimum External Clock High/Low Time }}{50 \%-\text { Percentage Variation of External Clock Input Duty Cycle }}
$$

### 3.3.2 Clock Synthesizer Operation

$V_{\text {DDSYN }}$ is used to power the clock circuits when the system clock is synthesized from either a crystal or an externally supplied reference frequency. A separate power source increases MCU noise immunity and can be used to run the clock when the MCU is powered down. A quiet power supply must be used as the $\mathrm{V}_{\text {DDSYN }}$ source. Adequate external bypass capacitors should be placed as close as possible to the $\mathrm{V}_{\text {DDSYN }}$ pin to assure stable operating frequency. When an external system clock signal is applied and the PLL is disabled, $\mathrm{V}_{\mathrm{DDSYN}}$ should be connected to the $\mathrm{V}_{\mathrm{SS}}$ supply. Refer to the SCIM Reference Manual (SCIMRM/AD) for more information regarding system clock power supply conditioning.

A voltage controlled oscillator (VCO) in the PLL generates the system clock signal. To maintain a $50 \%$ clock duty cycle, the VCO frequency ( $f_{v c o}$ ) is either two or four times the system clock frequency, depending on the state of the X bit in SYNCR. The clock signal is fed back to a divider/ counter. The divider controls the frequency of one input to a phase comparator. The other phase comparator input is a reference signal, either from the crystal oscillator or from an external source. The comparator generates a control signal proportional to the difference in phase between the two inputs. This signal is low-pass filtered and used to correct the VCO output frequency.

Filter circuit implementation can vary, depending upon the external environment and required clock stability. Figure 7 shows a recommended system clock filter network. XFC pin leakage must be kept as low as possible to maintain optimum stability and PLL performance.

An external filter network connected to the XFC pin is not required when an external system clock signal is applied and the PLL is disabled ( $\mathrm{V}_{\text {DDSYN }}=0$ ). The XFC pin must be left floating in this case.


* MAINTAIN LOW LEAKAGE ON THE XFC NODE.

Figure 7 System Clock Filter Network

The synthesizer locks when the VCO frequency is equal to $\mathrm{f}_{\text {ref. }}$. Lock time is affected by the filter time constant and by the amount of difference between the two comparator inputs. Whenever a comparator input changes, the synthesizer must relock. Lock status is shown by the SLOCK bit in SYNCR. During power-up, the MCU does not come out of reset until the synthesizer locks. Crystal type, characteristic frequency, and layout of external oscillator circuitry affect lock time.

When the clock synthesizer is used, SYNCR determines operating frequency and certain operating parameters. The W and $\mathrm{Y}[5: 0]$ bits are located in the PLL feedback path, enabling frequency multiplication by a factor of up to 256 . When the W or Y values change, VCO frequency changes, and there is a VCO relock delay. The SYNCR X bit controls a divide-by circuit that is not in the synthesizer feedback loop. When $\mathrm{X}=0$ (reset state), a divide-by-four circuit is enabled, and the system clock frequency is one-fourth the VCO frequency ( $\mathrm{f}_{\mathrm{VCO}}$ ). When $\mathrm{X}=1$, a divide-by-two circuit is enabled, and system clock frequency is one-half the VCO frequency ( $\mathrm{f}_{\mathrm{VCO}}$ ). There is no relock delay when clock speed is changed by the X bit.

Clock frequency is determined by SYNCR bit settings as follows:

$$
f_{\text {sys }}=\frac{f_{r e f}}{128}\left[4(Y+1)\left(2^{(2 W+X)}\right)\right]
$$

The reset state of SYNCR (\$3F00) results in a power-on $f_{\text {sys }}$ of 16.78 MHz when the $f_{\text {ref }}$ is 4.194 MHz.

For the device to perform correctly, the clock and frequency selected by the $\mathrm{W}, \mathrm{X}$, and Y bits must be within the limits specified for the MCU.

Internal VCO frequency is determined by the following equations:

$$
\begin{gathered}
\mathrm{f}_{\mathrm{VCO}}=4 \mathrm{f}_{\text {sys }} \text { if } \mathrm{X}=0 \\
\text { or } \\
\mathrm{f}_{\mathrm{VCO}}=2 \mathrm{f}_{\text {sys }} \text { if } \mathrm{X}=1
\end{gathered}
$$

### 3.3.3 Clock Control

The clock control circuits determine system clock frequency and clock operation under special circumstances, such as loss of synthesizer reference or low-power mode. Clock source is determined by the logic state of the MODCLK pin during reset.

| SYNCR - Clock Synthesizer Control Register |  |  |  |  |  |  |  |  |  |  |  |  |  | \$YFFA04 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| W | X | $\mathrm{Y}[5: 0]$ |  |  |  |  |  | EDIV | 0 | 0 | RSVD ${ }^{1}$ | SLOCK | RSVD ${ }^{1}$ | STSCIM | STEXT |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | U | 0 | 0 | 0 |

1. Ensure that initialization software does not change the value of this bit. It should always be zero.

When the on-chip clock synthesizer is used, system clock frequency is controlled by the bits in the upper byte of SYNCR. Bits in the lower byte show the status of, or control the operation of, internal and external clocks. Because the CPU16 always operates in supervisor mode, SYNCR can be read or written at any time.

W- Frequency Control Bit
This bit controls a prescaler tap in the synthesizer feedback loop. Setting the bit increases the VCO speed by a factor of four. VCO relock delay is required.

X - Frequency Control Bit
This bit controls a divide by two prescaler that is not in the synthesizer feedback loop. Setting it doubles clock speed without changing VCO speed. There is no VCO relock delay.

Y[5:0] - Frequency Control
The $Y$ field controls the modulus down counter in the synthesizer feedback loop, which effectively allows frequency multiplication by a value of $\mathrm{Y}+1$. VCO relock delay is required.

EDIV - ECLK Divide Rate
$0=$ ECLK frequency is system clock divided by 8
1 = ECLK frequency is system clock divided by 16
ECLK is an external M6800 bus clock available on pin ADDR23. Refer to 3.9 Chip Selects for more information.

SLOCK - Synthesizer Lock Flag
$0=\mathrm{VCO}$ is enabled, but has not locked
$1=\mathrm{VCO}$ has locked on the desired frequency (or system clock is external)
The MCU remains in reset until the synthesizer locks, but SLOCK does not indicate synthesizer lock status until after the user writes to SYNCR.

STSCIM - Stop Mode SCIM Clock
$0=$ When LPSTOP is executed, the SCIM clock is driven from the crystal oscillator and the VCO is turned off to conserve power.
$1=$ When LPSTOP is executed, the SCIM clock is driven from the VCO.
STEXT - Stop Mode External Clock
$0=$ When LPSTOP is executed, the CLKOUT signal is held negated to conserve power.
$1=$ When LPSTOP is executed, the CLKOUT signal is driven from the SCIM clock, as determined by the state of the STSCIM bit.

### 3.3.4 Periodic Interrupt Timer

The periodic interrupt timer (PIT) generates interrupts of specified priorities at specified intervals. Timing for the PIT is provided by a programmable prescaler driven by the system clock.

PICR — Periodic Interrupt Control Register
\$YFFA22


This register contains information concerning periodic interrupt priority and vectoring. Bits [10:0] can be read or written at any time. Bits [15:11] are unimplemented and always return zero.

PIRQL[2:0] - Periodic Interrupt Request Level
Table 14 shows what interrupt request level is asserted when a periodic interrupt is generated. If a PIT interrupt and an external interrupt request of the same priority occur simultaneously, the PIT interrupt is serviced first. The periodic timer continues to run when the interrupt is disabled.

Table 14 Periodic Interrupt Request Levels

| PIRQL | Interrupt Request Level |
| :---: | :---: |
| 000 | Periodic Interrupt Disabled |
| 001 | Interrupt Request Level 1 |
| 010 | Interrupt Request Level 2 |
| 011 | Interrupt Request Level 3 |
| 100 | Interrupt Request Level 4 |
| 101 | Interrupt Request Level 5 |
| 110 | Interrupt Request Level 6 |
| 111 | Interrupt Request Level 7 |

PIV[7:0] — Periodic Interrupt Vector
The bits of this field contain the vector generated in response to an interrupt from the periodic timer. When the SCIM responds, the periodic interrupt vector is placed on the bus.

PITR — Periodic Interrupt Timer Register
\$YFFA24

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | PTP |  |  | 0 | PITM[7:0] |  |  |  |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | $\overline{M O D C L K}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

PITR contains the count value for the periodic timer. A zero value turns off the periodic timer. This register can be read or written at any time.

PTP — Periodic Timer Prescaler Control
1 = Periodic timer clock prescaled by a value of 512
$0=$ Periodic timer clock not prescaled
The reset state of PTP is the complement of the state of the MODCLK signal during reset.
PITM[7:0] — Periodic Interrupt Timing Modulus Field
The PIT period can be calculated as follows:

$$
\text { PIT Period }=\frac{(\text { PITM }[7: 0])(\text { Prescale })(4)}{f_{\text {ref }}}
$$

where
PIT Period $=$ Periodic interrupt timer period
PITM[7:0] = Periodic interrupt timer register modulus
$\mathrm{f}_{\text {ref }}=$ Synthesizer reference of external clock input frequency
Prescale $=512$ or 1 depending on the state of the PTP bit in PITR

### 3.4 System Protection

System protection includes a bus monitor, a halt monitor, a spurious interrupt monitor, and a software watchdog timer. These functions reduce the number of external components required for a complete control system. Figure 8 shows the SCIM system protection block diagram.


Figure 8 System Protection Block

SYPCR - System Protection Control Register
\$YFFA21

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 |  | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | NOT USED |  |  |  |  | SWE | SWP |  | SWT[1:0] |  | HME | BME | BMT[1:0] |  |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  | 1 | $\overline{\text { MODCLK }}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

The system protection control register controls system monitor functions, software watchdog clock prescaling, and bus monitor timing. This register can only be written once following reset, but can be read at any time.

SWE - Software Watchdog Enable
0 = Software watchdog disabled
1 = Software watchdog enabled
SWP — Software Watchdog Prescale
This bit controls the value of the software watchdog prescaler.
$0=$ Software watchdog clock not prescaled
1 = Software watchdog clock prescaled by 512
The reset value of SWP is the complement of the state of the MODCLK pin during reset.

SWT[1:0] — Software Watchdog Timing
This field selects the divide ratio used to establish software watchdog time-out period. Table $\mathbf{1 5}$ gives the ratio for each combination of SWP and SWT bits.

Table 15 Software Watchdog Timeout Period Divide Ratio

| SWP | SWT[1:0] | Ratio |
| :---: | :---: | :---: |
| 0 | 00 | $2^{9}$ |
| 0 | 01 | $2^{11}$ |
| 0 | 10 | $2^{13}$ |
| 0 | 11 | $2^{15}$ |
| 1 | 00 | $2^{18}$ |
| 1 | 01 | $2^{20}$ |
| 1 | 10 | $2^{22}$ |
| 1 | 11 | $2^{24}$ |

HME - Halt Monitor Enable
$0=$ Disable halt monitor function
1 = Enable halt monitor function
BME - Bus Monitor Enable
$0=$ Disable bus monitor function for internal to external bus cycles.
1 = Enable bus monitor function for internal to external bus cycles.

BMT[1:0] - Bus Monitor Timing
This field selects a bus monitor time-out period as shown in Table 16.

Table 16 Bus Monitor Timeout Period

| BMT[1:0] | Time-Out |
| :---: | :---: |
| 00 | 64 System Clocks |
| 01 | 32 System Clocks |
| 10 | 16 System Clocks |
| 11 | 8 System Clocks |

### 3.4.1 Bus Monitor

The internal bus monitor checks for excessively long response times during normal bus cycles ( $\overline{\mathrm{DSACK1}}$ ) and during IACK cycles. The monitor asserts the internal BERR signal if response time is excessive.
$\overline{\text { DSACK1 }}$ response times are measured in clock cycles. The maximum allowable response time can be selected by setting BMT[1:0].

The monitor does not check $\overline{\text { DSACK1 }}$ response on the external bus unless the CPU16 initiates the bus cycle. The BME bit in SYPCR enables the internal bus monitor for internal to external bus cycles. If a system contains external bus masters, an external bus monitor must be implemented, and the internal to external bus monitor option must be disabled.

### 3.4.2 Halt Monitor

The halt monitor responds to an assertion of HALT on the internal bus, caused by a double bus fault. This signal is asserted by the CPU after a double bus fault occurs. A flag in the reset status register (RSR) indicates that the last reset was caused by the halt monitor. The halt monitor reset can be inhibited by the HME bit in the SYPCR.

### 3.4.3 Spurious Interrupt Monitor

The spurious interrupt monitor causes a bus error exception if no interrupt arbitration occurs during an interrupt acknowledge cycle. The most common cause of spurious interrupts is failure to set the module configuration register IARB[3:0] to a non-zero value for modules that can generate interrupts.

### 3.4.4 Software Watchdog

| SWS | S |  | atc | g | ce |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| UNUSED |  |  |  |  |  |  |  | SWSR |  |  |  |  |  |  |  |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

The software watchdog service register (SWSR) is controlled by SWE in SYPCR. Once enabled, the watchdog requires that a service sequence be written to SWSR on a periodic basis. If servicing does not take place, the watchdog times out and issues a reset. This register can be written at any time, but returns zeros when read.

Each time the service sequence is written, the software watchdog timer restarts. The sequence to restart consists of the following steps:

- Write $\$ 55$ to SWSR
- Write \$AA to SWSR

Both writes must occur before timeout in the order listed, but any number of instructions, up to the end of the timeout period, can be executed between the two writes.

Watchdog clock rate is affected by SWP and SWT[1:0] in SYPCR.
When SWT[1:0] are modified, a watchdog service sequence must be performed before the new time-out period will take effect.

The reset value of SWP is the complement of the state of the MODCLK pin on the rising edge of reset.

Software watchdog time-out period is given in the following equation:

$$
\text { Timeout Period }=\frac{\text { Divide Ratio Specified by SWP and SWT[1:0] }}{f_{\text {ref }}}
$$

### 3.5 External Bus Interface

The external bus interface (EBI) transfers information between the internal MCU bus and external devices when the MCU is operating in expanded modes. In 16-bit expanded mode, the external bus has 24 address lines and 16 data lines. In 8 -bit expanded mode, the external bus has 24 address lines and 8 data lines. Because the CPU16 drives only 20 of the 24 IMB address lines, ADDR[23:20] follow the output state of ADDR19.

The EBI supports byte, word, and long-word transfers. Ports are accessed through the use of asynchronous cycles controlled by the data transfer size (SIZ1 and SIZO) and the data size acknowledge pin (DSACK1).

Port width is the maximum number of bits accepted or provided during a bus transfer. External devices must follow the handshake protocol described below. Control signals indicate the beginning of the cycle, the address space, the size of the transfer, and the type of cycle. The selected device controls the length of the cycle. Strobe signals, one for the address bus and another for the data bus, indicate the validity of an address and provide timing information for data. The EBI operates in an asynchronous mode for any port width.

To add flexibility and minimize the necessity for external logic, MCU chip select logic can be synchronized with EBI transfers. Chip select logic can also provide internally-generated bus control signals for these accesses. Refer to 3.9 Chip Selects for more information.

### 3.6 Bus Control Signals

The CPU initiates a bus cycle by driving the address, size, function code, and read/write outputs. At the beginning of the cycle, size signals SIZ0 and SIZ1 are driven along with the function code signals. The size signals indicate the number of bytes remaining to be transferred during an operand cycle. They are valid while the address strobe ( $\overline{\mathrm{AS}}$ ) is asserted. Table 17 shows SIZ0 and SIZ1 encoding. The read/write (R/W) signal determines the direction of the transfer during a bus cycle. This signal changes state, when required, at the beginning of a bus cycle, and is valid while $\overline{\text { AS }}$ is asserted. R/W only transitions when a write cycle is preceded by a read cycle or vice versa. The signal can remain low for two consecutive write cycles.

Table 17 Size Signal Encoding

| SIZ1 | SIZ0 | Transfer Size |
| :---: | :---: | :---: |
| 0 | 1 | Byte |
| 1 | 0 | Word |
| 1 | 1 | Three Byte |
| 0 | 0 | Long Word |

### 3.6.1 Function Codes

Function code signals $\mathrm{FC}[2: 0$ ] are automatically generated by the CPU16. The function codes can be considered address extensions that automatically select one of eight address spaces to which an address applies. These spaces are designated as either user or supervisor, and program or data spaces. Because the CPU16 always operates in supervisor mode (FC2 always $=1$ ), address spaces 0 to 3 are not used. Address space 7 is designated CPU space. CPU space is used for control information not normally associated with read or write bus cycles. Function codes are valid while $\overline{\mathrm{AS}}$ is asserted.

Table 18 displays CPU16 address space encodings.

Table 18 CPU16 Address Space Encoding

| FC2 | FC1 | FC0 | Address Space |
| :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | Reserved |
| 1 | 0 | 1 | Supervisor Data Space |
| 1 | 1 | 0 | Supervisor Program Space |
| 1 | 1 | 1 | CPU Space |

### 3.6.2 Address Bus

Address bus signals ADDR[19:0] define the address of the most significant byte to be transferred during a bus cycle. The MCU places the address on the bus at the beginning of a bus cycle. The address is valid while $\overline{\text { AS }}$ is asserted. The CPU16 drives ADDR[23:20] to the same logic state as ADDR19.

### 3.6.3 Address Strobe

$\overline{\mathrm{AS}}$ is a timing signal that indicates the validity of an address on the address bus and of many control signals. It is asserted one-half clock after the beginning of a bus cycle.

### 3.6.4 Data Bus

Data bus signals DATA[15:0] comprise a bidirectional, non-multiplexed parallel bus that transfers data to or from the MCU. A read or write operation can transfer 8 or 16 bits of data in one bus cycle. During a read cycle, the data is latched by the MCU on the last falling edge of the clock for that bus cycle. For a write cycle, all 16 bits of the data bus are driven, regardless of the port width or operand size. The MCU places the data on the data bus one-half clock cycle after $\overline{\mathrm{AS}}$ is asserted in a write cycle.

### 3.6.5 Data Strobe

Data strobe $(\overline{\mathrm{DS}})$ is a timing signal. For a read cycle, the MCU asserts $\overline{\mathrm{DS}}$ to signal an external device to place data on the bus. $\overline{\mathrm{DS}}$ is asserted at the same time as $\overline{\mathrm{AS}}$ during a read cycle. For a write cycle, $\overline{\mathrm{DS}}$ signals an external device that data on the bus is valid. The MCU asserts $\overline{\mathrm{DS}}$ one full clock cycle after the assertion of $\overline{\mathrm{AS}}$ during a write cycle.

### 3.6.6 Bus Cycle Termination Signals

During bus cycles, external devices assert a data transfer and size acknowledge signal ( $\overline{\mathrm{DSACK}})$. During a read cycle, the signal tells the MCU to terminate the bus cycle and to latch data. During a write cycle, the signal indicates that an external device has successfully stored data and that the cycle can terminate. The $\overline{\text { DSACK1 }}$ signal also indicates to the MCU the size of the port for the bus cycle just completed. In the MC68HC916X1, the $\overline{\text { DSACKO }}$ pin is not provided and an external device indicates the availability of data by asserting DSACK1 regardless of port size.

The bus error ( $\overline{\mathrm{BERR}})$ signal is also a bus cycle termination indicator and can be used in the absence of DSACK1 to indicate a bus error condition. BERR can also be asserted in conjunction with $\overline{\text { DSACK1, }}$, provided $\overline{B E R R}$ meets the appropriate timing requirements. The internal bus monitor can be used to generate the BERR signal for internal and internal-to-external transfers. When BERR is asserted, the CPU16 takes a bus error exception.

### 3.6.7 Data Transfer Mechanism

MCU architecture supports byte, word, and long-word operands, allowing access to 8 - and 16-bit data ports through the use of asynchronous cycles.

The MCU always attempts to transfer the maximum amount of data on all bus cycles. For a word operation, it is assumed that the port is 16 bits wide when the bus cycle begins. Operand bytes are designated as shown in Figure 9. OP0 is the most significant byte of a long-word operand, and OP3 is the least significant byte. The two bytes of a word-length operand are OPO (most significant) and OP1. The single byte of a byte-length operand is OP0.


Figure 9 Operand Byte Order

### 3.6.8 Operand Alignment

The data multiplexer establishes the necessary connections for different combinations of address and data sizes. The multiplexer takes the two bytes of the 16 -bit bus and routes them to their required positions. Positioning of bytes is determined by the size and address outputs.

SIZ1 and SIZ0 indicate the remaining number of bytes to be transferred during the current bus cycle. The number of bytes transferred is equal to or less than the size indicated by SIZ1 and SIZO, depending on port width.

ADDR0 also affects the operation of the data multiplexer. During an operand transfer, ADDR[23:1] indicate the word base address of the portion of the operand to be accessed, and ADDR0 indicates the byte offset from the base. Bear in mind the fact that ADDR[23:20] are driven to the same logic state as ADDR19.

### 3.6.9 Misaligned Operands

CPU16 processor architecture uses a basic operand size of 16 bits. An operand is misaligned when it overlaps a word boundary. This is determined by the value of ADDRO. When ADDR0 $=0$ (an even address), the address is on a word and byte boundary. When ADDR0 $=1$ (an odd address), the address is on a byte boundary only. A byte operand is aligned at any address; a word or long-word operand is misaligned at an odd address.

The largest amount of data that can be transferred by a single bus cycle is an aligned word. If the MCU transfers a long-word operand via a 16-bit port, the most significant operand word is transferred on the first bus cycle and the least significant operand word on a following bus cycle.

The CPU16 can perform misaligned word transfers. This capability makes it software compatible with the M68HC11 CPU. The CPU16 treats misaligned long-word transfers as two misaligned word transfers.

### 3.6.10 Operand Transfer Cases

Table 19 shows how operands are aligned for various types of transfers. OPn entries are portions of a requested operand that are read or written during a bus cycle and are defined by SIZ1, SIZO, and ADDRO for that bus cycle.

Table 19 Operand Alignment

| Transfer Case | SIZ1 | SIZO | ADDR0 | DATA[15:8] | DATA[7:0] |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Byte to 16-Bit Port (Even) | 0 | 1 | 0 | OP0 | (OP0) ${ }^{1}$ |
| Byte to 16-Bit Port (Odd) | 0 | 1 | 1 | (OP0) ${ }^{1}$ | OPO |
| Word to 16-Bit Port (Aligned) | 1 | 0 | 0 | OP0 | OP1 |
| Word to 16-Bit Port (Misaligned) | 1 | 0 | 1 | (OP0) ${ }^{1}$ | OP0 |
| 3 Byte to 16-Bit Port (Aligned) ${ }^{2}$ | 1 | 1 | 0 | OP0 | OP1 |
| 3 Byte to 16-Bit Port (Misaligned) ${ }^{2}$ | 1 | 1 | 1 | (OP0) ${ }^{1}$ | OP0 |
| Long Word to 16-Bit Port (Aligned) | 0 | 0 | 0 | OP0 | OP1 |
| Long Word to 16-Bit Port (Misaligned) ${ }^{3}$ | 1 | 0 | 1 | (OP0) ${ }^{1}$ | OP0 |

1. Operands in parentheses are ignored by the CPU16 during read cycles.
2. Three-byte transfer cases occur only as a result of long word to byte transfer.
3. The CPU16 treats misaligned long-word transfers as two misaligned word transfers.

It is not possible to perform transfers of word operands to an 8-bit port on the MC68HC916X1 because the DSACKO pin is not present and therefore cannot be asserted to acknowledge the transfer. This limitation can be overcome by using SCIM chip-select logic to generate $\overline{\text { DSACK }}$ for such transfers.

### 3.7 Resets

Reset procedures handle system initialization and recovery from catastrophic failure. The MCU performs resets with a combination of hardware and software. The SCIM determines whether a reset is valid, asserts control signals, performs basic system configuration and boot ROM selection based on hardware mode-select inputs, then passes control to the CPU16.

Reset occurs when an active low logic level on the RESET pin is clocked into the SCIM. Resets are gated by the CLKOUT signal. Asynchronous resets are assumed to be catastrophic. An asynchronous reset can occur on any clock edge. Synchronous resets are timed to occur at the end of bus cycles. If there is no clock when RESET is asserted, reset does not occur until the clock starts. Resets are clocked to allow completion of write cycles in progress at the time RESET is asserted.

Reset is the highest-priority CPU16 exception. Any processing in progress is aborted by the reset exception, and cannot be restarted. Only essential tasks are performed during reset exception processing. Other initialization tasks must be accomplished by the exception handler routine.

### 3.7.1 SCIM Reset Mode Selection

The logic states of certain MCU pins during reset determine SCIM operating configuration. Refer to 3.2.1 Operating Modes for more information.

### 3.7.2 MCU Module Pin Function During Reset

Module pins usually default to port functions, and input/output ports are set to input state. This is accomplished by disabling pin functions in the appropriate control registers, and by clearing the appropriate port data direction registers. For more information, refer to the sections of this technical summary that present information about the individual modules. Table $\mathbf{2 0}$ is a summary of module pin functions out of reset.

Table 20 Module Pin Functions

| Module | Pin Mnemonic | Function |
| :---: | :---: | :---: |
| ADC | PADA[7:0]/AN[7:0] | Discrete Input |
|  | VRH | Reference Voltage |
|  | VRL | Reference Voltage |
| CPU | DSI/IPIPE1 | DSI/IPIPE1 |
|  | DSO/IPIPE0 | DSO/IPIPE0 |
|  | BKPT/DSCLK | BKPT/DSCLK |
| GPT | PGP7/IC4/OC5 | Discrete Input |
|  | PGP[6:3]/OC[4:1] | Discrete Input |
|  | PGP[2:0]/IC[3:1] | Discrete Input |
|  | PAI | Discrete Input |
|  | PCLK | Discrete Input |
|  | PWMA, PWMB | Discrete Output |
| QSM | PQS7/MOSI | Discrete Input |
|  | PQS6/MISO | Discrete Input |
|  | PQS5/SCK | Discrete Input |
|  | PQS4/PCS3 | Discrete Input |
|  | PQS3/PCS2 | Discrete Input |
|  | PQS2/PCS1 | Discrete Input |
|  | PQS1/PCS0/SS | Discrete Input |
|  | PQS0/TXD | Discrete Input |
|  | RXD | RXD |

### 3.7.3 Reset Timing

The RESET input must be asserted for a specified minimum period in order for reset to occur. External RESET assertion can be delayed internally for a period equal to the longest bus cycle time (or the bus monitor time-out period) to protect write cycles from being aborted by reset. While $\overline{\text { RESET }}$ is asserted, SCIM pins are either in an inactive, high-impedance state or are driven to their inactive states.

When an external device asserts RESET for the proper period, reset control logic clocks the signal into an internal latch. The control logic drives the RESET pin low for an additional 512 CLKOUT cycles after it detects that the RESET signal is no longer being externally driven, to guarantee this length of reset to the entire system.

If an internal source asserts a reset signal, the reset control logic asserts RESET for a minimum of 512 cycles. If the reset signal is still asserted at the end of 512 cycles, the control logic continues to assert RESET until the internal reset signal is negated.

After 512 cycles have elapsed, the reset input pin goes to an inactive, high-impedance state for 10 cycles. At the end of this 10 -cycle period, the reset input is tested. When the input is at logic level one, reset exception processing begins. If, however, the reset input is at logic level zero, the reset control logic drives the pin low for another 512 cycles. At the end of this period, the pin again goes to high-impedance state for ten cycles, then it is tested again. The process repeats until RESET is released.

### 3.7.4 Power-On Reset

When the SCIM clock synthesizer is used to generate system clocks, power-on reset involves special circumstances related to the application of system and clock synthesizer power. Regardless of clock source, voltage must be applied to the clock synthesizer power input pin $V_{\text {DDSYN }}$, so that the MCU can operate. The following discussion assumes that $\mathrm{V}_{\text {DDSYN }}$ is applied before and during reset. This minimizes crystal start-up time. When $\mathrm{V}_{\mathrm{DDSY}}$ is applied at power-on, start-up time is affected by specific crystal parameters and by oscillator circuit design. $\mathrm{V}_{\mathrm{DD}}$ ramp-up time also affects pin state during reset.

During power-on reset, an internal circuit in the SCIM drives the IMB internal and external reset lines. The circuit releases the internal reset line as $V_{D D}$ ramps up to the minimum specified value, and SCIM pins are initialized. When $V_{D D}$ reaches the specified minimum value, the clock synthesizer VCO begins operation. Clock frequency ramps up to the specified limp mode frequency. The external RESET line remains asserted until the clock synthesizer PLL locks and 512 CLKOUT cycles elapse.

The SCIM clock synthesizer provides clock signals to the other MCU modules. After the clock is running and the internal reset signal is asserted for four clock cycles, these modules reset. $\mathrm{V}_{\mathrm{DD}}$ ramp time and VCO frequency ramp time determine how long these four cycles take. Worst case is approximately 15 milliseconds. During this period, module port pins may be in an indeterminate state. While input-only pins can be put in a known state by means of external pull-up resistors, external logic on input/output or output-only pins must condition the lines during this time. Active drivers require high-impedance buffers or isolation resistors to prevent conflict.

### 3.7.5 Use of Three-State Control Pin

Asserting the three-state control (TSC) input causes all MCU output drivers to go to an inactive, high-impedance condition. Although TSC is an active-high input, it does not have an internal pulldown and must be tied low when not in use.

TSC must remain asserted for ten system clock cycles for drivers to change state. There are certain constraints on use of TSC during power-up reset.

When the internal clock synthesizer is used (MODCLK held high during reset), synthesizer rampup time affects how long ten clock cycles take. Worst case is approximately 20 milliseconds from TSC assertion.

When an external clock signal is applied (MODCLK held low during reset), pins go to high-impedance state as soon after TSC assertion as ten clock pulses have been applied to the EXTAL pin.

## NOTE

When TSC assertion takes effect, internal signals are forced to values that can cause inadvertent mode selection. Once the output drivers change state, the MCU must be powered down and restarted before normal operation can resume.

### 3.8 Interrupts

Interrupt recognition and servicing involve complex interaction between the central processing unit, the single-chip integration module, and a device or module requesting interrupt service.

The CPU16 provides for seven levels of interrupt priority (1-7), seven automatic interrupt vectors, and 200 assignable interrupt vectors. All interrupts with priorities less than seven can be masked by the interrupt priority (IP) field in the condition code register. The CPU16 handles interrupts as a type of asynchronous exception.

Interrupt recognition is based on the states of interrupt request signals $\overline{\mathrm{IRQ7}}$ and the IP mask value. Each of the signals corresponds to an interrupt priority. $\overline{\mathrm{IRQ1}}$ has the lowest priority, and $\overline{\mathrm{RQ} 7}$ has the highest priority.

## NOTE

On the MC68HC916X1, the only external interrupts available are IRQ6 and IRQ7.
The IP field consists of three bits (CCR[7:5]). Binary values \%000 to \%111 provide eight priority masks. Masks prevent an interrupt request of a priority less than or equal to the mask value (except for IRQ7) from being recognized and processed. When IP contains $\% 000$, no interrupt is masked. During exception processing, the IP field is set to the priority of the interrupt being serviced.

Interrupt request signals can be asserted by external devices or by microcontroller modules. Request lines are connected internally by a wired-NOR. Simultaneous requests with different priorities can be made. Internal assertion of an interrupt request signal does not affect the logic state of the corresponding MCU pin.

External interrupt requests are routed to the CPU16 through the external bus interface and SCIM interrupt control logic. The CPU treats external interrupt requests as though they had come from the SCIM.

External $\overline{\mathrm{RQ} 6}$ is an active-low level-sensitive input. External $\overline{\mathrm{RQ7}}$ is an active-low transition-sensitive input. It requires both an edge and a voltage level for validity.
$\overline{\mathrm{IRQ6}}$ is maskable. $\overline{\mathrm{RQ} 7}$ is non-maskable. The $\overline{\mathrm{RQ} 7}$ input is transition-sensitive to prevent redundant servicing and stack overflow. A non-maskable interrupt is generated each time IRQ7 is asserted, and each time the priority mask changes from \%111 to a lower number while $\overline{\mathrm{RQ}} \mathbf{7}$ is asserted.

Interrupt requests are sampled on consecutive falling edges of the system clock. Interrupt request input circuitry has hysteresis. To be valid, a request signal must be asserted for at least two consecutive clock periods. Valid requests do not cause immediate exception processing, but are left pending. Pending requests are processed at instruction boundaries or when exception processing of higher-priority exceptions is complete.

The CPU16 does not latch the priority of a pending interrupt request. If an interrupt source of higher priority makes a service request while a lower priority request is pending, the higher priority request is serviced. If an interrupt request of equal or lower priority than the current IP mask value is made, the CPU does not recognize the occurrence of the request in any way.

### 3.8.1 Interrupt Acknowledge and Arbitration

Interrupt acknowledge bus cycles are generated during exception processing. When the CPU16 detects one or more interrupt requests of a priority higher than the interrupt priority mask value, it performs a CPU space read from address \$FFFFF: [IP] : 1.

The CPU space read cycle performs two functions: it places a mask value corresponding to the highest priority interrupt request on the address bus, and it acquires an exception vector number from the interrupt source. The mask value also serves two purposes: it is latched into the CCR IP field to mask lower-priority interrupts during exception processing, and it is decoded by modules that have requested interrupt service to determine whether the current interrupt acknowledge cycle pertains to them.

Modules that have requested interrupt service decode the IP value placed on the address bus at the beginning of the interrupt acknowledge cycle. If their requests are at the specified IP level, they respond to the cycle. Arbitration between simultaneous requests of the same priority is performed by serial contention between module interrupt arbitration (IARB) field bit values.

Each module that can make an interrupt service request, including the SCIM, has an IARB field in its configuration register. An IARB field can be assigned a value from \%0001 (lowest priority) to \%1111 (highest priority). A value of $\% 0000$ in an IARB field causes the CPU16 to process a spurious interrupt exception when an interrupt from that module is recognized.

Because the EBI manages external interrupt requests, the SCIM IARB value is used for arbitration between internal and external interrupt requests. The reset value of IARB for the SCIM is \%1111. The reset IARB value for all other modules is \%0000. Initialization software must assign different IARB values to implement an arbitration scheme.

Each module must have a unique IARB value. When two or more IARB fields have the same nonzero value, the CPU16 interprets multiple vector numbers simultaneously, with unpredictable consequences.

Arbitration must always take place, even when a single source requests service. This point is important for two reasons: the CPU interrupt acknowledge cycle is not driven on the external bus unless the SCIM wins contention, and failure to contend causes an interrupt acknowledge bus cycle to be terminated by a bus error, which causes a spurious interrupt exception to be taken.

When arbitration is complete, the dominant module must place an interrupt vector number on the data bus and terminate the bus cycle. In the case of an external interrupt request, because the interrupt acknowledge cycle is transferred to the external bus, an external device must decode the mask value and respond with a vector number, then generate bus cycle termination signals. If the device does not respond in time, a spurious interrupt exception is taken.

The periodic interrupt timer (PIT) in the SCIM can generate internal interrupt requests of specific priority at predetermined intervals. By hardware convention, PIT interrupts are serviced before external interrupt service requests of the same priority. Refer to 3.3.4 Periodic Interrupt Timer for more information.

### 3.8.2 Interrupt Processing

The following summary outlines the interrupt processing sequence. When the sequence begins, a valid interrupt service request has been detected and is pending.
A. The CPU finishes higher priority exception processing or reaches an instruction boundary.
B. Processor state is stacked, then the CCR PK extension field is cleared.
C. The interrupt acknowledge cycle begins:

1. $\mathrm{FC}[2: 0]$ are driven to $\% 111$ (CPU space) encoding.
2. The address bus is driven as follows. ADDR[23:20] = \%1111; ADDR[19:16] = \%1111, which indicates that the cycle is an interrupt acknowledge CPU space cycle; AD$\operatorname{DR}[15: 4]=\% 1111111111$; $\operatorname{ADDR}[3: 1]=$ the priority of the interrupt request being acknowledged; and ADDR0 $=\% 1$.
3. Request priority is latched into the CCR IP field from the address bus.
D. Modules or external peripherals that have requested interrupt service decode the priority value on ADDR[3:1]. If request priority is the same as the priority value in the address, IARB contention takes place. When there is no contention, the spurious interrupt monitor asserts $\overline{B E R R}$, and a spurious interrupt exception is processed.
E. After arbitration, the interrupt acknowledge cycle can be completed in one of three ways:
4. The dominant interrupt source supplies a vector number and $\overline{\text { DSACK1 }}$ signals appropriate to the access. The CPU16 acquires the vector number.
5. Chip-select logic asserts $\overline{\text { AVEC }}$ internally and the CPU16 generates an autovector number corresponding to interrupt priority.
6. The bus monitor asserts BERR and the CPU16 generates the spurious interrupt vector number.
F. The vector number is converted to a vector address.
G. The content of the vector address is loaded into the PC, and the processor transfers control to the exception handler routine.

### 3.9 Chip Selects

Typical microcontrollers require additional hardware to provide external chip-select signals. The MC68HC916X1 includes five general-purpose programmable chip select circuits that can provide 2 - to 13 -clock cycle access to external memory and peripherals. Two additional chip select signals, $\overline{\text { CSE }}$ and CSM, provide emulation support. Address block sizes of 2 Kbytes to 1 Mbyte can be selected. However, because the CPU16 drives ADDR[23:20] to the same logic state as ADDR19, 512-Kbyte blocks are the largest usable size. Refer to 3.2.5 Emulation Support for more information.

Chip select assertion can be synchronized with bus control signals to provide output enable, read/ write strobes, or interrupt acknowledge signals. Logic can also generate $\overline{\text { DSACK }}$ and $\overline{\text { AVEC }}$ signals internally. A single DSACK generator is shared by all circuits. Multiple chip selects assigned to the same address and control must have the same number of wait states. Chip selects can also be synchronized with the ECLK signal available on ADDR23.

When a memory access occurs, chip select logic compares address space type, address, type of access, transfer size, and interrupt priority (in the case of interrupt acknowledge) to parameters stored in chip select registers. If all parameters match, a chip select signal is asserted. Select signals are active low. Figure $\mathbf{1 0}$ shows a single chip-select circuit.


Figure 10 Chip-Select Circuit Block Diagram

If a chip select function is given the same address as a microcontroller module or memory array, an access to that address goes to the module or array, and the chip select signal is not asserted.

Each chip-select pin has two or more functions. Configuration out of reset is determined by operating mode. In single-chip mode, all chip select pins except $\overline{\mathrm{CS} 10}$ and $\overline{\mathrm{CSO}}$ are configured for alternate functions or discrete output. In expanded modes, appropriate pins are configured for chip select operation, but chip select signals cannot be asserted until a transfer size is chosen. In fully expanded mode, data bus pins can be held low to enable alternate chip-select pin functions.

Table 21 shows allocation of chip selects and discrete outputs to MCU pins.

Table 21 Chip Select Pin Allocation

| Chip Select Function | Alternate Function | Discrete Outputs Function |
| :---: | :---: | :---: |
| $\overline{\mathrm{CSO}}$ | $\overline{\mathrm{BR}}$ | - |
| $\overline{\mathrm{CSM}}$ | $\overline{\mathrm{BG}}$ | - |
| $\overline{\mathrm{CSE}}$ | $\overline{\mathrm{BGACK}}$ | - |
| $\overline{\mathrm{CS3}}$ | $\mathrm{FC0}$ | $\mathrm{PC0}$ |
| - | FC 1 | PC 1 |
| $\overline{\mathrm{CS5}}$ | FC2 | PC2 |
| $\overline{\mathrm{CS}} \overline{\mathrm{CS}}$ | ADDR19 | PC3 |
| $\overline{\mathrm{CS} 10}$ | ADDR23 | ECLK |

### 3.9.1 Chip Select Registers

Pin assignment registers (CSPAR) determine functions of chip select pins. Pin assignment registers also determine port size (8- or 16-bit) for dynamic bus allocation.

A pin data register (PORTC) latches discrete output data.
Blocks of addresses are assigned to each chip select function. Block sizes of 2 Kbytes to 1 Mbyte can be selected by writing values to the appropriate base address register (CSBAR). However, because the logic state of ADDR20 is always the same as the state of ADDR19, the largest usable block size is 512 Kbytes. Address blocks for separate chip-select functions can overlap, however, they must have the same number of wait states if they do.

Chip-select option registers (CSOR) determine timing of and conditions for assertion of chip-select signals. Eight parameters, including operating mode, access size, synchronization, and wait state insertion can be specified.

### 3.9.2 Pin Assignment Registers

The pin assignment registers contain pairs of bits that determine the functions of chip-select pins. Table 22 shows pin assignment field encoding. Pin functions are shown in Tables 23 and $\mathbf{2 4}$ following the register diagrams.

Reset state of the pin assignment registers depends on operating mode. In the register diagrams, reset values are shown in the following order: single-chip mode, 8 -bit expanded mode, and 16 -bit expanded mode. The notation DATA\# indicates that a bit goes to the logic level of that data bus pin on reset. Data bus lines have weak pull-ups. During reset in 16-bit expanded mode, an active external device can pull the data lines low to select alternate functions.

CSPARO - Chip Select Pin Assignment Register 0
\$YFFA44

| 15 | 14 | 1312 | 1110 | 98 | 76 | $5 \quad 4$ | 32 | 10 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | CSPAO[13:12] | CSPAO[11:10] | CSPAO[9:8] | CSPA0[7:6] | CSPAO[5:4] | CSPA0[3:2] | RESERVED |


| SINGLE-CHIP MODE |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 000 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 |
| 8-BIT EXPANDED MODE |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $0 \quad 0 \quad 1$ | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 |
| 16-BIT EXPANDED MODE |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 00 DATA2 | 1 | 0 | 1 | DATA2 | 1 | $\overline{\text { DATA10 }}$ | 1 | $\overline{\text { DATA10 }}$ | 1 | DATA2 | 1 | 0 | 0 |

CSPAR1 - Chip Select Pin Assignment Register 1
\$YFFA46

| 15 |
| :--- |
| 14 |
| 14 |
| 0 |

SINGLE-CHIP MODE

| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 8-BIT EXPANDED MODE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |
| 16-BIT EXPANDED MODE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | DATA7 | 1 | DATA6 | 1 | DATA5 | 1 | DATA4 | 1 | DATA3 | 1 |

Clearing both CS10 select bits (CSPAR1[9:8]) enables the M6800 bus clock (ECLK) on ADDR23.

Table 22 Pin Assignment Field Encoding

| Bit Pair | Description |
| :---: | :---: |
| 00 | Discrete Output |
| 01 | Alternate Function |
| 10 | Chip Select (8-Bit Port) |
| 11 | Chip Select (16-Bit Port) |

Table 23 CSPARO Pin Functions

| CSPAR0 Field | Chip-Select Signal | Alternate Signal | Discrete Output |
| :---: | :---: | :---: | :---: |
| CSPA0[13:12] | $\overline{\mathrm{CS5}}$ | FC2 | PC2 |
| CSPA0[11:10] | - | FC1 | PC1 |
| CSPA0[9:8] | $\overline{\mathrm{CS} 3}$ | FC0 | PC0 |
| CSPA0[7:6] | $\overline{\mathrm{CSE}}$ | $\overline{\mathrm{BGACK}}$ | - |
| CSPA0[5:4] | $\overline{\mathrm{CSM}}$ | $\overline{\mathrm{BG}}$ | - |
| CSPA0[3:2] | $\overline{\mathrm{CS0}}$ | $\overline{\mathrm{BR}}$ | - |

Table 24 CSPAR1 Pin Functions

| CSPAR1 Field | Chip-Select Signal | Alternate Signal | Discrete Output |
| :---: | :---: | :---: | :---: |
| CSPA1 $[9: 8]$ | $\overline{\text { CS10 }}$ | ADDR23 | ECLK |
| CSPA1[7:6] | - | - | - |
| CSPA1[5:4] | - | - | - |
| CSPA1[3:2] | - | - | - |
| CSPA1[1:0] | CS6 | ADDR19 | PC3 |

A pin programmed as a discrete output drives an external signal to the value specified in the port C data register (PORTC), with the following exceptions:

- No discrete output function is available on pins $\overline{B R}, \overline{B G}$, or $\overline{\mathrm{BGACK}}$.
- ADDR23 provides ECLK output rather than a discrete output signal.

Internal chip select logic is inhibited when discrete output or alternate function are assigned.
Port size is determined when a pin is assigned as a chip select. When a pin is assigned to an 8 -bit port, the chip select is asserted at all addresses within the block range. If a pin is assigned to a 16bit port, the upper/lower byte field of the option register selects the byte with which the chip select is associated.

### 3.9.3 Base Address Registers

A base address is the starting address for the block enabled by a given chip select. Block size determines the extent of the block above the base address. Each chip select has an associated base register so that an efficient address map can be constructed for each application. If a chip select is assigned an address used by a microcontroller module, the module has priority. The chip select does not respond to an access.

| CSBARBT - Chip-Select Base Address Register Boot ROM |  |  |  |  |  |  |  |  |  |  |  |  |  | \$YFFA48 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| $\begin{gathered} \text { ADDR } \\ 23 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 22 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 21 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 20 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 19 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 18 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 17 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 16 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 15 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 14 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 13 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 12 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 11 \end{gathered}$ |  | BLKSZ[2:0] |  |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |

CSBAR[0:10] — Chip-Select Base Address Registers

## \$YFFA4C-\$YFFA74

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { ADDR } \\ 23 \end{gathered}$ | $\begin{gathered} \hline \text { ADDR } \\ 22 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 21 \end{gathered}$ | $\begin{gathered} \hline \text { ADDR } \\ 20 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 19 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 18 \end{gathered}$ | $\begin{gathered} \hline \text { ADDR } \\ 17 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 16 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 15 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 14 \end{gathered}$ | $\begin{gathered} \hline \text { ADDR } \\ 13 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 12 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 11 \end{gathered}$ |  | BLKSZ[2:0] |  |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

ADDR[23:20] is at the same logic level as ADDR19 during internal CPU master operation. ADDR[23:20] must match ADDR19 for the chip select to be active.

## NOTE

$\overline{\text { CSBOOT }}$ is not present on the MC68HC916X1, however, the $\overline{\text { CSBOOT }}$ chip-select logic is still present and should be disabled before other chip-selects are initialized.

ADDR[23:11] — Base Address Field
This field sets the starting address of a particular address space. The address compare logic uses only the most significant bits to match an address within a block. The value of the base address must be a multiple of block size. Base address register diagrams show how base register bits correspond to address lines.

Since ADDR20 = ADDR19 in the CPU16, the maximum block size is 512 Kbytes. Because ADDR[23:20] follow the logic state of ADDR19, if all 24 address lines are used, addresses from $\$ 080000$ to \$F7FFFF are inaccessible.

BLKSZ[2:0] — Block Size Field
This field determines the size of the block above the base address that must be enabled by the chip select. Table 25 shows bit encoding for the base address registers block size field.

Table 25 Block Size Field Bit Encoding

| BLKSZ[2:0] | Block Size | Address Lines Compared |
| :---: | :---: | :---: |
| 000 | 2 K | ADDR[23:11] |
| 001 | 8 K | ADDR[23:13] |
| 010 | 16 K | ADDR[23:14] |
| 011 | 64 K | ADDR[23:16] |
| 100 | 128 K | ADDR[23:17] |
| 101 | 256 K | ADDR[23:18] |
| 110 | 512 K | ADDR[23:19] |
| 111 | 512 K | ADDR[23:20] |

1. During normal operation $\operatorname{ADDR}[23: 20]$ is at the same logic level as ADDR19.

### 3.9.4 Option Registers

The option registers contain eight fields that determine timing of and conditions for assertion of chip select signals. These make the chip selects useful for generating peripheral control signals. Certain constraints set by fields in the base address register and in the option register must be satisfied to assert a chip select signal and to provide DSACK or autovector support.

CSORBT - Chip-Select Option Register Boot ROM
\$YFFA4A


CSOR[0:10] - Chip-Select Option Registers
\$YFFA4E-YFFA76


NOTE
CSBOOT is not present on the MC68HC916X1, however, the CSBOOT chip-select logic is still present and should be disabled before other chip-selects are initialized.

The following bit descriptions apply to both CSORBT and CSOR[10:0] option registers.
MODE - Asynchronous/Synchronous Mode
0 = Asynchronous mode selected
1 = Synchronous mode selected
In asynchronous mode, the chip select is asserted synchronized with AS or DS.
In synchronous mode, the $\overline{\text { DSACK }}$ field is not used because a bus cycle is only performed as a synchronous operation. When a match condition occurs on a chip select programmed for synchronous operation, the chip select signals the EBI that an E-clock cycle is pending.

BYTE[1:0] - Upper/Lower Byte Option
This field is used only when the chip select 16 -bit port option is selected in the pin assignment register.
Table 26 lists upper/lower byte options.

Table 26 Byte Field Bit Encoding

| BYTE[1:0] | Description |
| :---: | :---: |
| 00 | Disable |
| 01 | Lower Byte |
| 10 | Upper Byte |
| 11 | Both Bytes |

$R / \bar{W}[1: 0]$ - Read/Write
This field causes a chip select to be asserted only for a read, only for a write, or for both read and write.
Table 27 shows the options.

Table 27 Read/Write Bit Encodings

| $\mathbf{R} / \overline{\mathbf{W}}[1: 0]$ | Description |
| :---: | :---: |
| 00 | Disable |
| 01 | Read Only |
| 10 | Write Only |
| 11 | Read/Write |

STRB - Address Strobe/Data Strobe
0 = Address strobe
1 = Data strobe
This bit controls the timing for assertion of a chip select in asynchronous mode. Selecting address strobe causes chip select to be asserted synchronized with address strobe. Selecting data strobe causes chip select to be asserted synchronized with data strobe.

## $\overline{\text { DSACK[3:0] }}$ - Data and Size Acknowledge

This field specifies the source of DSACK in asynchronous mode. It also allows the user to adjust bus timing with internal DSACK generation by controlling the number of wait states that are inserted to optimize bus speed in a particular application. Table 28 shows the DSACK[3:0] field encoding. A no-wait encoding (\%0000) corresponds to a three clock-cycle bus. The fast termination encoding (\%1110) corresponds to a two clock-cycle bus. Microcontroller modules typically respond at this rate, but fast termination can also be used to access fast external memory.

Table 28 DSACK Field Encoding

| DSACK[3:0] | Clock Cycles Required <br> Per Access | Wait States Inserted <br> Per Access |
| :---: | :---: | :---: |
| 0000 | 3 | 0 |
| 0001 | 4 | 1 |
| 0010 | 5 | 2 |
| 0011 | 6 | 3 |
| 0100 | 7 | 4 |
| 0101 | 8 | 5 |
| 0110 | 9 | 6 |
| 0111 | 10 | 7 |
| 1000 | 11 | 8 |
| 1001 | 12 | 9 |
| 1010 | 13 | 10 |
| 1011 | 14 | 11 |
| 1100 | 15 | 12 |
| 1101 | 2 | 13 |
| 1110 | - | External DSACK |
| 1111 |  |  |

SPACE[1:0] - Address Space Select
This option field is used to select an address space to be used by the chip select logic. The CPU16 normally operates in supervisor space. All space types can be used. Interrupt acknowledge cycles take place in CPU space. Table 29 shows address space bit encodings.

Table 29 Address Space Bit Encodings

| SPACE[1:0] | Address Space |
| :---: | :---: |
| 00 | CPU Space |
| 01 | User Space $^{1}$ |
| 10 | Supervisor Space $^{11}$ |
| 11 | Supervisor/User Space $^{1}$ |

1. The CPU16 executes code only in supervisor mode, therefore this space field encoding has no effect. Supervisor/User space is equivalent to supervisor space encoding.

IPL[2:0] - Interrupt Priority Level
When the SPACE[1:0] field is set for CPU space (\%00), chip-select logic can be used for interrupt acknowledge. During an interrupt acknowledge cycle, the priority level on address lines ADDR[3:1] is compared to the value in the IPL[2:0] field. If the values are the same, then a chip-select can be asserted, provided other option register conditions are met. When the SPACE[1:0] field has any value except $\% 00$, the IPL[2:0] field determines whether an access takes place in program or data space. Table 30 shows IPL[2:0] field encoding.

Table 30 Interrupt Priority Level Field Encoding

| IPL[2:0] | SPACE[1:0] = 00 | SPACE[1:0] = 01, 10, 11 |
| :---: | :---: | :---: |
| 000 | All | Data or Program |
| 001 | IPL1 | Data |
| 010 | IPL2 | Program |
| 011 | IPL3 | Reserved |
| 100 | IPL4 | Reserved |
| 101 | IPL5 | Data |
| 110 | IPL6 | Program |
| 111 | IPL7 | Reserved |

1. "All" means that a chip select signal is asserted regardless of the priority of the interrupt.

This field only affects the response of chip selects and does not affect interrupt recognition by the CPU.
$\overline{\text { AVEC }}$ - Autovector Enable
0 = External interrupt vector enabled
1 = Autovector enabled
This field selects one of two methods of acquiring the interrupt vector during the interrupt acknowledge cycle. It is not usually used with a chip select pin.

If the chip select is configured to trigger on an interrupt acknowledge cycle (SPACE[1:0] = \%00) and the $\overline{\text { AVEC field is set to one, the chip select automatically generates an AVEC in response to the interrupt }}$ acknowledge cycle. Otherwise, the vector must be supplied by the requesting device.

### 3.9.5 Port C Data Register

Bit values in port $C$ determine the state of chip-select pins used for discrete output. When a pin is assigned as a discrete output, the value in this register appears at the output. This is a read/write register. Bit 7 is not used. Writing to this bit has no effect, and it always returns zero when read.

| PORTC - Port C Data Register |  |  |  |  |  |  |  |  |  |  |  |  |  | \$YFFA41 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| NOT USED |  |  |  |  |  |  |  | 0 | RESERVED |  |  | PC3 | PC2 | PC1 | PC0 |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

### 3.9.6 Chip Select Reset Operation

The reset values of the chip select pin assignment fields in CSPAR0 and CSPAR1 depend on the operating mode selected. Refer to 3.2.1 Operating Modes and to the discussion of these registers for more information.

The BYTE[1:0] field in option register CSORBT has a reset value of both bytes, but CSOR[10:0] have a reset value of disable, as they should not select external devices until an initial program sets up the base and option registers.

### 3.10 General-Purpose Input/Output

The SCIM contains six general-purpose input/output ports: ports A, B, E, F, G, and H. (Port C, an output-only port, is included under the discussion of chip selects). Ports A, B, and G are available in single-chip mode only and port H is available in single-chip or 8 -bit expanded modes only. Ports $\mathrm{E}, \mathrm{F}, \mathrm{G}$, and H have an associated data direction register to configure each pin as input or output. Ports $A$ and $B$ share a data direction register that configures each port as input or output. Ports E and F have associated pin assignment registers that configure each pin as digital I/O or an alternate function. Port F has an edge-detect flag register that indicates whether a transition has occurred on any of its pins.

Table 31 shows the shared functions of the general-purpose I/O ports and the modes in which they are available.

Table 31 General-Purpose I/O Ports

| Port | Shared Function | Modes |
| :---: | :---: | :---: |
| A | ADDR[18:11] | Single Chip |
| B | ADDR[10:3] | Single Chip |
| E | Bus Control | All |
| F | $\overline{\mathrm{RQQ}[7: 6] / \text { MODCLK }}$ | All |
| G | DATA[15:8] | Single Chip |
| H | DATA[7:0] | Single Chip, 8-Bit Expanded |

Access to the port A, B, E, F, G, and H data and data direction registers, and the port C, E, and F pin assignment registers require three clock cycles to ensure timing compatibility with external port replacement logic. Port registers are byte-addressable and are grouped to allow coherent word access to port data register pairs A-B and G-H, as well as word-aligned long word coherency of A-B-G-H port data registers.

If emulation mode is enabled, the emulation mode chip-select signal $\overline{\text { CSE }}$ is asserted whenever an access to ports $\mathrm{A}, \mathrm{B}, \mathrm{E}, \mathrm{G}$, and H data and data direction registers or the port E pin assignment register is made. The SCIM does not respond to these accesses, but allows external logic, such as a Motorola port replacement unit (PRU) MC68HC33 to respond. Port C data and data direction register, port F data and data direction register, and the port F pin assignment register remain accessible.

A write to the port A, B, E, F, G, or H data register is stored in the internal data latch. If any port pin is configured as an output, the value stored for that bit is driven on the pin. A read of the port data register returns the value at the pin only if the pin is configured as a discrete input. Otherwise, the value read is the value stored in the register.

### 3.10.1 Ports A and B

Ports A and B are available in single-chip mode only. One data direction register controls data direction for both ports. Port A and B registers can be read or written at any time the MCU is not in emulator mode.

| $\begin{aligned} & \text { POR } \\ & \text { POR } \end{aligned}$ | $\begin{aligned} & -P \\ & -P \end{aligned}$ | rt A | ta R | ister |  |  |  |  |  |  |  |  |  | $\begin{aligned} & \text { \$YFF } \\ & \text { \$YFF } \end{aligned}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PA7 | PA6 | PA5 | PA4 | PA3 | PA2 | PA1 | PAO | PB7 | PB6 | PB5 | PB4 | PB3 | PB2 | PB1 | PB0 |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| U | U | U | U | U | U | u | U | U | U | U | U | U | U | U | U |

DDRAB — Port A/B Data Direction Register
\$YFFA14

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | DDA | DDB |  |  |  | DDRE |  |  |  |  |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ | $U$ |

DDA and DDB control the direction of the pin drivers for ports $A$ and $B$, respectively, when the pins are configured for I/O. Setting DDA or DDB to one configures all pins in the corresponding port as outputs. Clearing DDA or DDB to zero configures all pins in the corresponding port as inputs.

### 3.10.2 Port E

Port E can be made available in all operating modes. The state of $\overline{\mathrm{BERR}}$ and DATA8 during reset controls whether the port E pins are used as bus control signals or discrete I/O lines.

If the MCU is in emulator mode, an access of the port $E$ data, data direction, or pin assignment registers (PORTE, DDRE, PEPAR) is forced to go external. This allows port replacement logic to be supplied externally, giving an emulator access to the bus control signals.

PORTEO, PORTE1 — Port E Data Register
\$YFFA11, YFFA13


1. Reserved

PORTE is a single register that can be accessed in two locations. It can be read or written at any time the MCU is not in emulator mode.

DDRE - Port E Data Direction Register


1. Reserved

The bits in this register control the direction of the pin drivers when the pins are configured as I/O. Any bit in this register set to one configures the corresponding pin as an output. Any bit in this register cleared to zero configures the corresponding pin as an input. This register can be read or written at any time the MCU is not in emulator mode.

PEPAR — Port E Pin Assignment

## \$YFFA17



SINGLE-CHIP MODE

| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

1. Reserved

The bits in PEPAR control the function of each port E pin. Any bit set to one defines the corresponding pin to be a bus control signal, with the function shown in Table 32. Any bit cleared to zero defines the corresponding pin to be an I/O pin, controlled by PORTE and DDRE.

Table 32 Port E Pin Assignments

| PEPAR Bit | Port E Signal | Bus Control Signal |
| :---: | :---: | :---: |
| PEPA7 | PE7 | $\mathrm{SIZ1}$ |
| PEPA6 | PE6 | $\mathrm{SIZ0}$ |
| PEPA5 | PE5 | $\overline{\mathrm{AS}}$ |
| PEPA4 | PE4 | $\overline{\mathrm{DS}}$ |
| PEPA1 | PE1 | DSACK1 |

$\overline{B E R R}$ and DATA8 control the state of this register following reset. If $\overline{B E R R}$ and/or DATA8 are low during reset, this register is set to $\$ 00$, defining all port E pins as I/O pins. If BERR and DATA8 are both high during reset, the register is set to $\$ \mathrm{FF}$, which defines all port E pins as bus control signals.

### 3.10.3 Port F

Port F pins can be configured as interrupt request inputs, edge-detect input/outputs, or discrete input/outputs. When port F pins are configured for edge detection, and a priority level is specified by writing a value to the port F edge-detect interrupt level register (PFLVR), port F control logic generates an interrupt request when the specified edge is detected. Interrupt vector assignment is made by writing a value to the port $F$ edge-detect interrupt vector register (PFIVR). The edge-detect interrupt has the lowest arbitration priority in the SCIM.


| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  | NOT USED |  | PF7 | PF6 |  | RESERVED |  |  |  |  |  |  |  |  |  |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

A write to the port $F$ data register is stored in the internal data latch, and if any port $F$ pin is configured as an output, the value stored for that bit is driven on the pin. A read of PORTF returns the value on a pin only if the pin is configured as a discrete input. Otherwise, the value read is the value stored in the data register.

Port $F$ is a single register that can be accessed in two locations. It can be read or written at any time, including when the MCU is in emulator mode.

DDRF - Port F Data Direction Register
\$YFFA1D


The bits in this register control the direction of port F pin drivers when the pins are configured for I/ O. Setting any bit in this register configures the corresponding pin as an output. Clearing any bit in this register configures the corresponding pin as an input.

PFPAR — Port F Pin Assignment Register
\$YFFA1F

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |$\quad 1 \quad 0$

RESET:
8- AND 16-BIT EXPANDED MODES
DATA9 DATA9 DATA9 DATA9 DATA9 DATA9 DATA9 DATA9

SINGLE-CHIP MODE

| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

The fields in this register determine the functions of pairs of port F pins. Table 33 shows port F pin assignments. Table 34 shows PFPAR pin functions.

In single-chip mode ( $\overline{\mathrm{BERR}}=0$ during reset), this register is set to $\$ 00$, defining all port $F$ pins to be I/O pins. In 8- and 16-bit expanded modes, the state of DATA9 during reset determines the default value for PFPAR.

Table 33 Port F Pin Assignments

| PFPAR Field | Port F Signal | Alternate Signal |
| :---: | :---: | :---: |
| PFPA $\left.^{7}: 6\right]^{1}$ | PF[7:6] | $\overline{\operatorname{RQ}[7: 6]}$ |
| ${\text { PFPA }[1: 0]^{1}}^{1}$ | PF[1:0] | MODCLK $^{2}$ |

1. $\operatorname{PF}[5: 2]$ are not connected. These bits have no meaning.
2. MODCLK signal is only recognized during reset.

Table 34 PFPAR Pin Functions

| PFPAx Bits | Port F Signal |
| :---: | :---: |
| 00 | I/O pin without edge detect |
| 01 | Rising edge detect |
| 10 | Falling edge detect |
| 11 | Interrupt request |



When the corresponding pin is configured for edge detection, a PORTFE bit is set if an edge is detected. PORTFE bits remain set, regardless of the subsequent state of the corresponding pin, until cleared. To clear a bit, first read PORTFE, then write the bit to zero. When a pin is configured for general-purpose I/O or for use as an interrupt request input, PORTFE bits do not change state.

PFIVR — Port F Edge-Detect Interrupt Vector Register
\$YFFA2B

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  | NOT USED |  |  |  |  |  |  |  |  |  |  |  |  |  |

This register determines which vector in the exception vector table is used for interrupts generated by the port F edge-detect logic. Program PFIVR[7:0] to the value pointing to the appropriate interrupt vector. Refer to 4 Central Processing Unit for interrupt vector assignments.

PFLVR — Port F Edge-Detect Interrupt Level Register
\$YFFA2D


PFLVR determines the priority level of the port F edge-detect interrupt. The reset value is $\$ 00$, indicating that the interrupt is disabled. When several sources of interrupts from the SCIM are arbitrating for the same level, the port F edge-detect interrupt has the lowest arbitration priority.

### 3.10.4 Port G

Port $G$ is available in single-chip mode only. These pins are always configured for use as generalpurpose I/O in single-chip mode.

### 3.10.5 Port H

Port H is available in single-chip and 8-bit expanded modes only. The function of these pins is determined by the operating mode. There is no pin assignment register associated with this port.

| PORTG — Port G Data Register <br> PORTH - Port H Data Register |  |  |  |  |  |  |  |  |  |  |  |  |  | \$YFFAOC <br> \$YFFAOD |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PG7 | PG6 | PG5 | PG4 | PG3 | PG2 | PG1 | PGO | PH7 | PH6 | PH5 | PH4 | PH3 | PH2 | PH1 | PH0 |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| U | U | U | U | U | U | U | U | U | U | U | U | U | U | U | U |

These port data registers can be read or written any time the MCU is not in emulation mode. Reset has no effect.

| DDRG — Port G Data Direction Register <br> DDRH - Port H Data Direction Register |  |  |  |  |  |  |  |  |  |  |  |  |  | \$YFFA0E <br> \$YFFAOF |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| DDG7 | DDG6 | DDG5 | DDG4 | DDG3 | DDG2 | DDG1 | DDGO | DDH7 | DDH6 | DDH5 | DDH4 | DDH3 | DDH2 | DDH1 | DDH0 |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

The bits in this register control the direction of the port pin drivers when pins are configured as I/O. Setting a bit configures the corresponding pin as an output. Clearing a bit configures the corresponding pin as an input.

### 3.11 Factory Test

Test functions are integrated into the SCIM to support scan-based testing of the various MCU modules during production. Test submodule registers are intended for Motorola use. Register names and addresses are provided to show the user that these addresses are occupied.

| SCIMTR — Single-Chip Integration Module Test Register | \$YFFA02 |
| :--- | :--- |
| SCIMTRE — Single-Chip Integration Module Test Register (E Clock) | \$YFFA08 |
| TSTMSRA — Master Shift Register A | \$YFFA30 |
| TSTMSRB — Master Shift Register B | \$YFFA32 |
| TSTSC — Test Module Shift Count | \$YFFA34 |
| TSTRC — Test Module Repetition Count | \$YFFA36 |
| CREG — Test Submodule Control Register | \$YFFA38 |
| DREG — Distributed Register | \$YFFA3A |

## 4 Central Processing Unit

The CPU16 is a true 16 -bit, high-speed device. It was designed to give M68HC11 users a path to higher performance while maintaining maximum compatibility with existing systems.

### 4.1 Overview

Ease of programming is an important consideration when using a microcontroller. The CPU16 instruction set is optimized for high performance. There are two 16-bit general-purpose accumulators and three 16 -bit index registers. The CPU16 supports 8 -bit (byte), 16-bit (word), and 32 -bit (longword) load and store operations, as well as 16 - and 32 -bit signed fractional operations. Code development is simplified by the background debugging mode.

CPU16 memory space includes a one Mbyte data space and a one Mbyte program space. Twentybit addressing and transparent bank switching are used to implement extended memory. In addition, most instructions automatically handle bank boundaries.

The CPU16 includes instructions and hardware to implement control-oriented digital signal processing functions with a minimum of interfacing. A multiply and accumulate unit provides the capability to multiply signed 16 -bit fractional numbers and store the resulting 32 -bit fixed point product in a 36 -bit accumulator. Modulo addressing supports finite impulse response filters.

Use of high-level languages is increasing as controller applications become more complex and control programs become larger. These languages make rapid development of portable software possible. The CPU16 instruction set supports high-level languages.

### 4.2 M68HC11 Compatibility

CPU16 architecture is a superset of M68HC11 CPU architecture. All M68HC11 CPU resources are available in the CPU16. M68HC11 CPU instructions are either directly implemented in the CPU16, or have been replaced by instructions with an equivalent form. The instruction sets are source code compatible, but some instructions are executed differently in the CPU16. These instructions are mainly related to interrupt and exception processing - M68HC11 CPU code that processes interrupts, handles stack frames, or manipulates the condition code register must be rewritten.

CPU16 execution times and number of cycles for all instructions are different from those of the M68HC11 CPU. As a result, cycle-related delays and timed control routines may be affected.

The CPU16 also has several new or enhanced addressing modes. M68HC11 CPU direct mode addressing has been replaced by a special form of indexed addressing that uses the new IZ register and a reset vector to provide greater flexibility.

### 4.3 Programming Model



Accumulator A - 8-bit general-purpose register
Accumulator B-8-bit general-purpose register
Accumulator D - 16-bit general-purpose register formed by concatenating accumulators A and B
Accumulator E - 16-bit general-purpose register
Index Register X - 16-bit indexing register, addressing extended by XK field in K register
Index Register Y - 16-bit indexing register, addressing extended by YK field in K register
Index Register $Z-16$-bit indexing register, addressing extended by $Z K$ field in K register
Stack Pointer - 16-bit dedicated register, addressing extended by the SK register
Program Counter - 16-bit dedicated register, addressing extended by PK field in CCR
Condition Code Register - 16-bit register containing condition flags, interrupt priority mask, and the program counter address extension field
K Register - 16-bit register made up of four 4-bit address extension fields
SK Register - 4-bit register containing the stack pointer address extension field
H Register - 16-bit multiply and accumulate input (multiplier) register
I Register - 16-bit multiply and accumulate input (multiplicand) register
MAC Accumulator - 36 -bit multiply and accumulate result register
XMSK, YMSK - Determine which bits change when an offset is added
Figure 11 CPU16 Programming Model

### 4.3.1 Condition Code Register



S - STOP Enable
0 = Stop clock when LPSTOP instruction is executed
$1=$ Perform NOP when LPSTOP instruction is executed
MV - Accumulator M overflow flag
MV is set when an overflow into AM35 has occurred.
H — Half Carry Flag
H is set when a carry from A3 or B3 occurs during BCD addition.

## EV — Extension Bit Overflow Flag

EV is set when an overflow into AM31 has occurred.
N - Negative Flag
$N$ is set when the MSB of a result register is set.

## Z — Zero Flag

Z is set when all bits of a result register are zero.
V - Overflow Flag
V is set when a two's complement overflow occurs as the result of an operation.

## C - Carry Flag

C is set when a carry or borrow occurs during an arithmetic operation. This flag is also used during shift and rotate to facilitate multiple word operations.

IP[2:0] — Interrupt Priority Field
The priority value in this field ( 0 to 7 ) is used to mask interrupts.

## SM — Saturate Mode Bit

When SM is set, if either EV or MV is set, data read from AM using TMER or TMET is given maximum positive or negative value, depending on the state of the AM sign bit before overflow.

PK[3:0] — Program Counter Address Extension Field
This field is concatenated with the program counter to form a 20-bit address.

### 4.4 Data Types

The CPU16 supports the following data types:

- Bit data
- 8 -bit (byte) and 16-bit (word) integers
- 32-bit long integers
- 16 -bit and 32 -bit signed fractions (MAC operations only)
- 20 -bit effective address consisting of 16 -bit page address plus 4 -bit extension

A byte is eight bits wide and can be accessed at any byte location. A word is composed of two consecutive bytes, and is addressed at the lower byte. Instruction fetches are always accessed on word boundaries. Word operands are normally accessed on word boundaries as well, but can be accessed on odd byte boundaries, with a substantial performance penalty.

To be compatible with the M68HC11, misaligned word transfers and misaligned stack accesses are allowed. Transferring a misaligned word requires two successive byte operations.

### 4.5 Addressing Modes

The CPU16 provides ten types of addressing. Each type encompasses one or more addressing modes. Six CPU16 addressing types are identical to M68HC11 addressing types.

All modes generate ADDR[15:0]. This address is combined with ADDR[19:16] from an extension field to form a 20 -bit effective address. Extension fields are part of a bank switching scheme that provides the CPU16 with a 1 Mbyte address space. Bank switching is transparent to most instructions. ADDR[19:16] of the effective address change when an access crosses a bank boundary. However, it is important to note that the value of the associated extension field is dependent on the type of instruction, and usually does not change as a result of effective address calculation.

In the immediate modes, the instruction argument is contained in bytes or words immediately following the instruction. The effective address is the address of the byte following the instruction. The AIS, AIX/Y/Z, ADDD and ADDE instructions have an extended 8 -bit mode where the immediate value is an 8 -bit signed number that is sign-extended to 16 bits, and then added to the appropriate register. Use of the extended 8 -bit mode decreases execution time.

Extended mode instructions contain ADDR[15:0] in the word following the opcode. The effective address is formed by concatenating EK and the 16-bit extension.

In the indexed modes, registers IX, IY, and IZ, together with their associated extension fields, are used to calculate the effective address. Signed 16 -bit mode and signed 20 -bit mode are extensions to the M68HC11 indexed addressing mode.

For 8-bit indexed mode, an 8-bit unsigned offset contained in the instruction is added to the value contained in the index register and its associated extension field.

For 16-bit mode, a 16-bit signed offset contained in the instruction is added to the value contained in the index register and its associated extension field.

For 20-bit mode, a 20 -bit signed offset is added to the value contained in the index register. This mode is used for JMP and JSR instructions.

Inherent mode instructions use information available to the processor to determine the effective address. Operands (if any) are system resources and are thus not fetched from memory.

Accumulator offset mode adds the contents of 16-bit accumulator E to one of the index registers and its associated extension field to form the effective address. This mode allows use of index registers and an accumulator within loops without corrupting accumulator D.

Relative modes are used for branch and long branch instructions. A byte or word signed two's complement offset is added to the program counter if the branch condition is satisfied. The new PC value, concatenated with the PK field, is the effective address.

Post-modified index mode is used with the MOVB and MOVW instructions. A signed 8 -bit offset is added to index register X after the effective address formed by XK and IX is used.

In M68HC11 systems, direct mode can be used to perform rapid accesses to RAM or I/O mapped into page 0 ( $\$ 0000$ to $\$ 00 F F$ ), but the CPU16 uses the first 512 bytes of page 0 for exception vectors. To compensate for the loss of direct mode, the ZK field and index register $Z$ have been assigned reset initialization vectors. By resetting the ZK field to a chosen page, and using 8 -bit unsigned index mode with IZ, a programmer can access useful data structures anywhere in the address map.

### 4.6 Instruction Set

The CPU16 instruction set is based on that of the M68HC11, but the opcode map has been rearranged to maximize performance with a 16 -bit data bus. All M68HC11 instructions are supported by the CPU16, although they may be executed differently. Most M68HC11 code runs on the CPU16 following reassembly. However, take into account changed instruction times, the interrupt mask, and the new interrupt stack frame.

The CPU16 has a full range of 16-bit arithmetic and logic instructions, including signed and unsigned multiplication and division. New instructions have been added to support extended addressing and digital signal processing.

Table 35 is a quick reference to the entire CPU16 instruction set. Because it is only affected by a few instructions, the LSB of the condition code register is not shown in the table. Instructions that affect the interrupt mask and PK field are noted. Table 36 provides a key to the table nomenclature.

Table 35 Instruction Set Summary

| Mnemonic | Operation | Description | Address | Instruction |  |  | Condition Codes |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Mode | Opcode | Operand | Cycles | S | MV | H EV | N | Z | V | C |
| ABA | Add B to A | ( A$)+(\mathrm{B}) \Rightarrow \mathrm{A}$ | INH | 370B | - | 2 | - | - | $\Delta$ - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ABX | Add B to IX | $(\mathrm{XK}: \mathrm{IX})+(000: B) \Rightarrow \mathrm{XK}: \mathrm{IX}$ | INH | 374F | - | 2 | - | - - | - - | - | - | - | - |
| ABY | Add B to IY | $(\mathrm{YK}: \mathrm{IY})+(000: B) \Rightarrow \mathrm{YK}: \mathrm{IY}$ | INH | 375F | - | 2 | - | - | - - | - | - | - | - |
| ABZ | Add B to IZ | $(Z K: I Z)+(000: B) \Rightarrow$ ZK : IZ | INH | 376F | - | 2 | - | - | - | - | - | - | - |
| ACE | Add E to AM | $(A M[31: 16])+(E) \Rightarrow A M$ | INH | 3722 | - | 2 | - | $\Delta$ | - $\Delta$ | - | - | - | - |
| ACED | Add E : D to AM | $(\mathrm{AM})+(\mathrm{E}: \mathrm{D}) \Rightarrow \mathrm{AM}$ | INH | 3723 | - | 4 | - | $\Delta$ | - $\Delta$ | - | - | - | - |
| ADCA | Add with Carry to A | $(\mathrm{A})+(\mathrm{M})+\mathrm{C} \Rightarrow \mathrm{A}$ | IND8, X <br> IND8, Y <br> IND8, Z <br> IMM8 <br> IND16, $X$ <br> IND16, Y <br> IND16, Z <br> EXT <br> E, X <br> E, Y <br> E, Z | 43 53 63 73 1743 1753 1763 1773 2743 2753 2763 | ff ff ff ii gggg gggg gggg hh II - - - | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 2 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ |  | - | $\Delta$ - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ADCB | Add with Carry to B | $(\mathrm{B})+(\mathrm{M})+\mathrm{C} \Rightarrow \mathrm{B}$ | IND8, X <br> IND8, Y <br> IND8, Z <br> IMM8 <br> IND16, X <br> IND16, $Y$ <br> IND16, Z <br> EXT <br> E, X <br> E, Y <br> E, Z | C3 D3 E3 F3 17C3 17D3 17E3 17F3 27C3 27D3 27E3 | ff ff ff ii gggg gg g gggg hh II - - - | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 2 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - | - | $\Delta$ - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ADCD | Add with Carry to D | (D) $+(M: M+1)+C \Rightarrow D$ | IND8, X <br> IND8, Y <br> IND8, Z <br> IMM16 <br> IND16, X <br> IND16, Y <br> IND16, Z <br> EXT <br> E, X <br> E, Y <br> E, Z | 83 93 A3 $37 B 3$ 37C3 37D3 37E3 $37 F 3$ 2783 2793 27A3 | ff ff ff $\mathrm{jj} k \mathrm{kk}$ gggg gggg gggg $\mathrm{hh} I I$ - - - | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 4 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ |  | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ADCE | Add with Carry to E | $(E)+(M: M+1)+C \Rightarrow E$ | IMM16 <br> IND16, X <br> IND16, Y <br> IND16, Z <br> EXT | $\begin{aligned} & 3733 \\ & 3743 \\ & 3753 \\ & 3763 \\ & 3773 \end{aligned}$ | $\begin{aligned} & \text { jj kk } \\ & \text { gggg } \\ & \text { gggg } \\ & \text { gggg } \\ & \text { hh II } \end{aligned}$ | $\begin{aligned} & \hline 4 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ADDA | Add to A | $(\mathrm{A})+(\mathrm{M}) \Rightarrow \mathrm{A}$ | IND8, X <br> IND8, Y <br> IND8, Z <br> IMM8 <br> IND16, X <br> IND16, Y <br> IND16, Z <br> EXT <br> E, X <br> E, Y <br> E, Z | 41 51 61 71 1741 1751 1761 1771 2741 2751 2761 | ff ff ff ii gggg gggg gggg hh II - - - | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 2 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - |  | $\Delta-$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

Table 35 Instruction Set Summary (Continued)


Table 35 Instruction Set Summary (Continued)


Table 35 Instruction Set Summary (Continued)

| Mnemonic | Operation | Description | Address <br> Mode | Instruction |  |  | Condition Codes |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Opcode | Operand | Cycles | S | MV | H | EV | N | Z | V | C |
| ASRA | Arithmetic Shift Right A |  | INH | 370D | - | 2 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ASRB | Arithmetic Shift Right B |  | INH | 371D | - | 2 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ASRD | Arithmetic Shift Right D | $\rightarrow \underset{b 15}{\square}---\underset{\text { b0 }}{\longrightarrow} \rightarrow \square$ | INH | 27FD | - | 2 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ASRE | Arithmetic Shift Right E | $\rightarrow \underset{b 15}{\square---\xrightarrow[b 0]{\longrightarrow}} \rightarrow \square$ | INH | 277D | - | 2 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ASRM | Arithmetic Shift Right AM |  | INH | 27BA | - | 4 | - | - | - | $\Delta$ | $\Delta$ | - | - | $\Delta$ |
| ASRW | Arithmetic Shift Right Word |  | $\begin{gathered} \text { IND16, X } \\ \text { IND16, } Y \\ \text { IND16, } Z \\ \text { EXT } \end{gathered}$ | $\begin{aligned} & \text { 270D } \\ & \text { 271D } \\ & 272 D \\ & 273 D \end{aligned}$ | gggg <br> gggg <br> gggg <br> hh II | $\begin{aligned} & 8 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| $\mathrm{BCC}^{2}$ | Branch if Carry Clear | If $\mathrm{C}=0$, branch | REL8 | B4 | rr | 6, 2 | - | - | - | - | - | - | - | - |
| BCLR | Clear Bit(s) | (M) • (Mask) $\Rightarrow \mathrm{M}$ | $\begin{aligned} & \text { IND8, X } \\ & \text { IND8, } Y \\ & \text { IND8, } Z \\ & \text { IND16, } X \\ & \text { IND16, } Y \\ & \text { IND16, } Z \\ & \text { EXT } \end{aligned}$ | 1708 1718 1728 08 18 28 38 | mm ff <br> mm ff <br> mm ff <br> mm gggg <br> mm gggg <br> mm gggg <br> mm hh | $\begin{aligned} & \hline 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| BCLRW | Clear Bit(s) in a Word | $\begin{gathered} (M: M+1) \cdot(\overline{\text { Mask }}) \Rightarrow \\ M: M+1 \end{gathered}$ | IND16, X <br> IND16, Y <br> IND16, Z <br> EXT | 2708 <br> 2718 <br> 2728 <br> 2738 | $\begin{gathered} \hline \text { gggg } \\ \mathrm{mmmm} \\ \text { gggg } \\ \mathrm{mmmm} \\ \text { gggg } \\ \mathrm{mmmm} \\ \mathrm{hh} \mathrm{II} \\ \mathrm{mmmm} \end{gathered}$ | $\begin{aligned} & 10 \\ & 10 \\ & 10 \\ & 10 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| $\mathrm{BCS}^{2}$ | Branch if Carry Set | If $\mathrm{C}=1$, branch | REL8 | B5 | rr | 6, 2 | - | - | - | - | - | - | - | - |
| $\mathrm{BEQ}^{2}$ | Branch if Equal | If $Z=1$, branch | REL8 | B7 | rr | 6, 2 | - | - | - | - | - | - | - | - |
| $B G E^{2}$ | Branch if Greater Than or Equal to Zero | If $\mathrm{N} \oplus \mathrm{V}=0$, branch | REL8 | BC | rr | 6, 2 | - | - | - | - | - | - | - | - |
| BGND | Enter Background Debug Mode | If BDM enabled, begin debug; else, illegal instruction trap | INH | 37A6 | - | - | - | - | - | - | - | - | - | - |
| BGT ${ }^{2}$ | Branch if Greater Than <br> Zero | If $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$, branch | REL8 | BE | rr | 6, 2 | - | - | - | - | - | - | - | - |
| $\mathrm{BHI}^{2}$ | Branch if Higher | If $\mathrm{C}+\mathrm{Z}=0$, branch | REL8 | B2 | rr | 6, 2 | - | - | - | - | - | - | - | - |
| BITA | Bit Test A | (A) • (M) | IND8, X <br> IND8, Y <br> IND8, Z <br> IMM8 <br> IND16, X <br> IND16, Y <br> IND16, Z <br> EXT <br> E, X <br> E, Y <br> E, Z | 49 59 69 79 1749 1759 1769 1779 2749 2759 2769 | ff ff ff ii gggg gggg gggg hh II - - - | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 2 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - |  | - | - | $\Delta$ | $\Delta$ | 0 | - |

Table 35 Instruction Set Summary (Continued)

| Mnemonic | Operation | Description | Address | Instruction |  |  | Condition Codes |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Mode | Opcode | Operand | Cycles | S | MV | H | EV | N | Z | V | C |
| BITB | Bit Test B | (B) • (M) | IND8, X <br> IND8, Y <br> IND8, Z <br> IMM8 <br> IND16, X <br> IND16, $Y$ <br> IND16, Z <br> EXT <br> E, X <br> E, Y <br> E, Z | C9 D9 E9 F9 17C9 17D9 17E9 17F9 27C9 27D9 27E9 | ff ff ff ii gggg $\mathrm{gg} g \mathrm{~g}$ gggg hh II - - - | $\begin{aligned} & 6 \\ & 6 \\ & 6 \\ & 2 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| $B L E^{2}$ | Branch if Less Than or Equal to Zero | If $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$, branch | REL8 | BF | rr | 6, 2 |  | - | - | - |  |  |  | - |
| BLS ${ }^{2}$ | Branch if Lower or Same | If $C+Z=1$, branch | REL8 | B3 | rr | 6, 2 | - | - | - | - |  |  |  | - |
| $\mathrm{BLT}^{2}$ | Branch if Less Than Zero | If $\mathrm{N} \oplus \mathrm{V}=1$, branch | REL8 | BD | rr | 6, 2 |  | - | - | - |  |  |  | - |
| $\mathrm{BMI}^{2}$ | Branch if Minus | If $\mathrm{N}=1$, branch | REL8 | BB | rr | 6, 2 |  | - | - | - |  |  | - | - |
| $\mathrm{BNE}^{2}$ | Branch if Not Equal | If $Z=0$, branch | REL8 | B6 | rr | 6, 2 | - | - | - | - | - |  |  | - |
| BPL ${ }^{2}$ | Branch if Plus | If $\mathrm{N}=0$, branch | REL8 | BA | rr | 6, 2 |  | - | - | - | - |  | - | - |
| BRA | Branch Always | If $1=1$, branch | REL8 | B0 | rr | 6 | - | - | - | - | - |  |  | - |
| BRCLR ${ }^{2}$ | Branch if Bit(s) Clear | If (M) $\bullet$ (Mask $)=0$, branch | IND8, X <br> IND8, Y <br> IND8, Z <br> IND16, X <br> IND16, Y <br> IND16, Z <br> EXT | CB <br> DB <br> EB <br> OA <br> 1A <br> 2A <br> 3A |  | $\begin{aligned} & 10,12 \\ & 10,12 \\ & 10,12 \\ & 10,14 \\ & 10,14 \\ & 10,14 \\ & 10,14 \end{aligned}$ | - | - | - | - | - |  | - | - |
| BRN | Branch Never | If $1=0$, branch | REL8 | B1 | rr | 2 |  | - | - | - | - |  | - | - |
| $\mathrm{BRSET}^{2}$ | Branch if Bit(s) Set | If ( $\overline{\mathrm{M}}) \cdot($ Mask $)=0$, branch | IND8, X IND8, Y IND8, Z IND16, X IND16, Y IND16, $Z$ EXT |  |  mm ff rr <br> mm ff rr  <br> mm ff rr <br> mm   <br> gggg rrrr  <br> mm   <br> gggg rrrr  <br> mm   <br> gggg rrrr  <br> mm hh II <br> rrrr   | $\begin{aligned} & 10,12 \\ & 10,12 \\ & 10,12 \\ & 10,14 \\ & 10,14 \\ & 10,14 \\ & 10,14 \end{aligned}$ | - | - | - | - | - |  | - | - |
| BSET | Set Bit(s) | $(\mathrm{M})+$ (Mask $) \Rightarrow \mathrm{M}$ | $\begin{aligned} & \hline \text { IND8, } X \\ & \text { IND8, } Y \\ & \text { IND8, } Z \\ & \text { IND16, } X \\ & \text { IND16, } Y \\ & \text { IND16, } Z \\ & \text { EXT } \end{aligned}$ | 1709 1719 1729 09 19 29 39 | mm mm mm mm mm mm mmgg mm mmgg mm mmgg mm hh II | $\begin{aligned} & \hline 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | $\Delta$ |
| BSETW | Set Bit(s) in Word | $\begin{gathered} (M: M+1)+(\text { Mask }) \\ \Rightarrow M: M+1 \end{gathered}$ | IND16, X <br> IND16, Y <br> IND16, Z <br> EXT | $\begin{aligned} & 2709 \\ & 2719 \\ & 2729 \\ & 2739 \end{aligned}$ | gggg <br> mmmm <br> gggg <br> mmmm <br> gggg <br> mmmm <br> hh II <br> mmmm | $\begin{aligned} & 10 \\ & 10 \\ & 10 \\ & 10 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | $\Delta$ |

Table 35 Instruction Set Summary (Continued)

| Mnemonic | Operation | Description | Address | Instruction |  |  | Condition Codes |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Mode | Opcode | Operand | Cycles | S | MV | H EV | N | Z | V | C |
| BSR | Branch to Subroutine | (PK : PC) $-2 \Rightarrow \mathrm{PK}: \mathrm{PC}$ Push (PC) (SK : SP) $-2 \Rightarrow$ SK : SP Push (CCR) (SK : SP) - $2 \Rightarrow$ SK : SP (PK : PC) + Offset $\Rightarrow$ PK : PC | REL8 | 36 | rr | 10 | - | - | - - |  | - | - | - |
| BVC ${ }^{2}$ | Branch if Overflow Clear | If $\mathrm{V}=0$, branch | REL8 | B8 | rr | 6, 2 | - | - | - |  | - | - | - |
| BVS ${ }^{2}$ | Branch if Overflow Set | If $\mathrm{V}=1$, branch | REL8 | B9 | rr | 6, 2 | - | - | - - |  | - | - | - |
| CBA | Compare A to B | (A) - (B) | INH | 371B | - | 2 | - | - | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| CLR | Clear a Byte in Memory | \$00 $\Rightarrow \mathrm{M}$ | $\begin{aligned} & \text { IND8, } X \\ & \text { IND8, } Y \\ & \text { IND8, } Z \\ & \text { IND16, } X \\ & \text { IND16, } Y \\ & \text { IND16, } Z \\ & \text { EXT } \end{aligned}$ | $\begin{gathered} \hline 05 \\ 15 \\ 25 \\ 1705 \\ 1715 \\ 1725 \\ 1735 \end{gathered}$ | ff ff ff gggg gggg gggg hh | $\begin{aligned} & \hline 4 \\ & 4 \\ & 4 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | 0 | 1 | 0 | 0 |
| CLRA | Clear A | \$00 $\Rightarrow$ A | INH | 3705 | - | 2 | - | - | - - | 0 | 1 | 0 | 0 |
| CLRB | Clear B | \$00 $\Rightarrow$ B | INH | 3715 | - | 2 | - | - | - - | 0 | 1 | 0 | 0 |
| CLRD | Clear D | \$0000 $\Rightarrow$ D | INH | 27F5 | - | 2 | - | - | - - | 0 | 1 | 0 | 0 |
| CLRE | Clear E | \$0000 $\Rightarrow$ E | INH | 2775 | - | 2 | - | - | - - | 0 | 1 | 0 | 0 |
| CLRM | Clear AM | \$000000000 $\Rightarrow$ AM[35:0] | INH | 27B7 | - | 2 | - | 0 | - 0 |  | - | - | - |
| CLRW | Clear a Word in Memory | \$0000 $\Rightarrow \mathrm{M}: \mathrm{M}+1$ | $\begin{aligned} & \text { IND16, X } \\ & \text { IND16, Y } \\ & \text { IND16, } Z \\ & \text { EXT } \end{aligned}$ | $\begin{aligned} & 2705 \\ & 2715 \\ & 2725 \\ & 2735 \end{aligned}$ | gggg <br> gggg <br> gggg <br> hh II | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | 0 | 1 | 0 | 0 |
| CMPA | Compare A to Memory | (A) - (M) | IND8, X <br> IND8, Y <br> IND8, Z <br> IMM8 <br> IND16, $X$ <br> IND16, Y <br> IND16, Z <br> EXT <br> E, X <br> E, Y <br> E, Z | 48 58 68 78 1748 1758 1768 1778 2748 2758 2768 | ff <br> ff <br> ff <br> ii <br> gggg <br> gggg <br> gggg <br> hh II <br> - <br> - | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 2 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| CMPB | Compare B to Memory | (B) - (M) | IND8, X <br> IND8, Y <br> IND8, Z <br> IMM8 <br> IND16, X <br> IND16, $Y$ <br> IND16, Z <br> EXT <br> E, X <br> E, Y <br> E, Z | C8 D8 E8 F8 17C8 17D8 17E8 17F8 27C8 27D8 27E8 | ff <br> ff <br> ff <br> ii <br> gggg <br> gggg <br> gggg <br> hh II <br> - <br> - <br> - | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 2 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - | — | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| COM | One's Complement | \$FF-(M) $\Rightarrow \mathrm{M}$, or $\overline{\mathrm{M}} \Rightarrow \mathrm{M}$ | $\begin{gathered} \text { IND8, } X \\ \text { IND8, } \mathrm{Y} \\ \text { IND8, } \mathrm{Z} \\ \text { IND16, } \mathrm{X} \\ \text { IND16, Y } \\ \text { IND16, Z } \\ \text { EXT } \end{gathered}$ | $\begin{gathered} \hline 00 \\ 10 \\ 20 \\ 1700 \\ 1710 \\ 1720 \\ 1730 \end{gathered}$ | ff ff ff gggg gggg gggg hh II | $\begin{aligned} & \hline 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ | - | - |  | $\Delta$ | $\Delta$ | 0 | 1 |
| COMA | One's Complement A | \$FF-(A) $\Rightarrow \mathrm{A}$, or $\overline{\mathrm{M}} \Rightarrow \mathrm{A}$ | INH | 3700 | - | 2 | - | - | - - | $\Delta$ | $\Delta$ | 0 | 1 |
| COMB | One's Complement B | \$FF-(B) $\Rightarrow \mathrm{B}$, or $\bar{B} \Rightarrow B$ | INH | 3710 | - | 2 | - | - | - - | $\Delta$ | $\Delta$ | 0 | 1 |
| COMD | One's Complement D | \$FFFF-(D) $\Rightarrow \mathrm{D}$, or $\overline{\mathrm{D}} \Rightarrow \mathrm{D}$ | INH | 27F0 | - | 2 | - | - | - - | $\Delta$ | $\Delta$ | 0 | 1 |
| COME | One's Complement E | \$FFFF - (E) $\Rightarrow \mathrm{E}$, or $\overline{\mathrm{E}} \Rightarrow \mathrm{E}$ | INH | 2770 | - | 2 | - | - | - | $\Delta$ | $\Delta$ | 0 | 1 |
| COMW | One's Complement Word | \$FFFF - M : M + $1 \Rightarrow$ $M: M+1$, or $(\overline{M: M+1}) \Rightarrow$ $M: M+1$ | $\begin{gathered} \text { IND16, X } \\ \text { IND16, } Y \\ \text { IND16, } Z \\ \text { EXT } \end{gathered}$ | $\begin{aligned} & 2700 \\ & 2710 \\ & 2720 \\ & 2730 \end{aligned}$ | $\begin{aligned} & \text { gggg } \\ & \text { gggg } \\ & \text { gggg } \\ & \text { hh II } \end{aligned}$ | $\begin{aligned} & 8 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ | - |  | - | $\Delta$ | $\Delta$ | 0 | 1 |

Table 35 Instruction Set Summary (Continued)


Table 35 Instruction Set Summary (Continued)

| Mnemonic | Operation | Description | Address | Instruction |  |  | Condition Codes |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Mode | Opcode | Operand | Cycles | S | MV | H | EV | N | Z | V | C |
| EDIVS | Extended Signed Integer Divide | $\begin{gathered} (\mathrm{E}: \mathrm{D}) /(\mathrm{IX}) \\ \text { Quotient } \Rightarrow \mathrm{IX} \\ \text { Remainder } \Rightarrow \mathrm{D} \end{gathered}$ | INH | 3729 | - | 38 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMUL | Extended Unsigned Multiply | (E) * D$) \Rightarrow \mathrm{E}: \mathrm{D}$ | INH | 3725 | - | 10 | - | - | - | - | $\Delta$ | $\Delta$ | - | $\Delta$ |
| EMULS | Extended Signed Multiply | $(\mathrm{E}) *(\mathrm{D}) \Rightarrow \mathrm{E}: \mathrm{D}$ | INH | 3726 | - | 8 | - | - | - | - | $\Delta$ | $\Delta$ | - | $\Delta$ |
| EORA | Exclusive OR A | $(\mathrm{A}) \oplus(\mathrm{M}) \Rightarrow \mathrm{A}$ | IND8, X <br> IND8, Y <br> IND8, Z <br> IMM8 <br> IND16, X <br> IND16, Y <br> IND16, Z <br> EXT <br> E, X <br> E, Y <br> E, Z | 44 54 64 74 1744 1754 1764 1774 2744 2754 2764 | ff <br> ff <br> ff <br> ii <br> gggg <br> gggg <br> gggg <br> hh II <br> - <br> - <br> - | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 2 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| EORB | Exclusive OR B | (B) $\oplus(\mathrm{M}) \Rightarrow \mathrm{B}$ | IND8, X <br> IND8, Y <br> IND8, Z <br> IMM8 <br> IND16, X <br> IND16, Y <br> IND16, Z <br> EXT <br> E, X <br> E, Y <br> E, Z | C4 D4 E4 F4 17C4 17D4 17E4 17F4 27C4 27D4 27E4 | ff <br> ff <br> ff <br> ii <br> gggg <br> gggg <br> gggg <br> hh II <br> - <br> - | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 2 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| EORD | Exclusive OR D | (D) $\oplus(M: M+1) \Rightarrow D$ | $\begin{aligned} & \hline \text { IND8, } X \\ & \text { IND8, } Y \\ & \text { IND8, } Z \\ & \text { IMM16 } \\ & \text { IND16, } X \\ & \text { IND16, } Y \\ & \text { IND16, } Z \\ & \text { EXT } \\ & \text { E, X } \\ & \text { E, Y } \\ & \text { E, Z } \end{aligned}$ | 84 94 A4 37B4 37C4 37D4 37E4 37F4 2784 2794 27A4 | ff ff ff $\mathrm{jj} k \mathrm{kk}$ gggg gggg gggg $\mathrm{hh} I I$ - - - | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 4 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ |  | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| EORE | Exclusive OR E | (E) $\oplus(M: M+1) \Rightarrow E$ | $\begin{aligned} & \text { IMM16 } \\ & \text { IND16, } X \\ & \text { IND16, Y } \\ & \text { IND16, } Z \\ & \text { EXT } \end{aligned}$ | $\begin{aligned} & 3734 \\ & 3744 \\ & 3754 \\ & 3764 \\ & 3774 \end{aligned}$ | $\begin{aligned} & \hline \text { jj kk } \\ & \text { gggg } \\ & \text { gggg } \\ & \text { gggg } \\ & \text { hh II } \end{aligned}$ | $\begin{aligned} & 4 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ |  | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| FDIV | Fractional Unsigned Divide | (D) / (IX) $\Rightarrow \mathrm{IX}$ <br> Remainder $\Rightarrow D$ | INH | 372B | - | 22 | - | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ |
| FMULS | Fractional Signed Multiply | $\begin{gathered} (E) *(D) \Rightarrow E: D[31: 1] \\ 0 \Rightarrow D[0] \end{gathered}$ | INH | 3727 | - | 8 | - | - | - |  | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| IDIV | Integer Divide | (D) / (IX) $\Rightarrow \mathrm{IX}$ <br> Remainder $\Rightarrow D$ | INH | 372A | - | 22 | - | - | - | - | - | $\Delta$ | 0 | $\Delta$ |
| INC | Increment Memory | (M) + \$01 $\Rightarrow \mathrm{M}$ | $\begin{aligned} & \hline \text { IND8, } X \\ & \text { IND8, } Y \\ & \text { IND8, } Z \\ & \text { IND16, } X \\ & \text { IND16, } Y \\ & \text { IND16, } Z \\ & \text { EXT } \end{aligned}$ | $\begin{gathered} \hline 03 \\ 13 \\ 23 \\ 1703 \\ 1713 \\ 1723 \\ 1733 \end{gathered}$ | ff ff ff gggg gggg gggg $\mathrm{hh} I I$ | $\begin{aligned} & \hline 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ | - | - | - |  | $\Delta$ | $\Delta$ | $\Delta$ | - |
| INCA | Increment A | (A) + \$01 $\Rightarrow \mathrm{A}$ | INH | 3703 | - | 2 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | - |
| INCB | Increment B | $(\mathrm{B})+\$ 01 \Rightarrow B$ | INH | 3713 | - | 2 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | - |
| INCW | Increment Memory Word | $\begin{aligned} & (M: M+1)+\$ 0001 \\ & \quad \Rightarrow M: M+1 \end{aligned}$ | $\begin{aligned} & \text { IND16, X } \\ & \text { IND16, } Y \\ & \text { IND16, } Z \\ & \text { EXT } \end{aligned}$ | 2703 2713 2723 2733 | gggg <br> gggg <br> gggg <br> hh II | $\begin{aligned} & \hline 8 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ | - | — | - | - | $\Delta$ | $\Delta$ | $\Delta$ | - |

Table 35 Instruction Set Summary (Continued)

| Mnemonic | Operation | Description | Address | Instruction |  |  | Condition Codes |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Mode | Opcode | Operand | Cycles | S | MV ${ }^{\text {H }}$ | EV | N | Z | V | C |
| JMP | Jump | $\langle\mathrm{ea}\rangle \Rightarrow \mathrm{PK}$ : PC | $\begin{aligned} & \text { EXT20 } \\ & \text { IND20, X } \\ & \text { IND20, Y } \\ & \text { IND20, Z } \end{aligned}$ | $\begin{aligned} & \text { 7A } \\ & 4 B \\ & 5 B \\ & 6 B \end{aligned}$ | $\begin{array}{\|c\|} \hline \text { zb hh II } \\ \text { zg gggg } \\ \text { zg gggg } \\ \text { zg gggg } \end{array}$ | $\begin{aligned} & \hline 6 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ |  | - | - | - | - | - | - |
| JSR | Jump to Subroutine | Push (PC) $($ SK : SP) $-\$ 0002 \Rightarrow$ SK : SP Push (CCR) $($ SK : SP) $-\$ 0002 \Rightarrow$ SK : SP $\langle$ ea $\rangle \Rightarrow$ PK : PC | $\begin{aligned} & \text { EXT20 } \\ & \text { IND20, X } \\ & \text { IND20, Y } \\ & \text { IND20, Z } \end{aligned}$ | $\begin{aligned} & \text { FA } \\ & 89 \\ & 99 \\ & \text { A9 } \end{aligned}$ | $\begin{array}{\|c\|} \hline \text { zb hh II } \\ \text { zg gggg } \\ \text { zg gggg } \\ \text { zg gggg } \end{array}$ | $\begin{aligned} & 10 \\ & 12 \\ & 12 \\ & 12 \end{aligned}$ | - | - | - | - | - | - | - |
| LBCC $^{2}$ | Long Branch if Carry Clear | If $\mathrm{C}=0$, branch | REL16 | 3784 | rrrr | 6, 4 |  | - - | - | - | - |  | - |
| LBCS $^{2}$ | Long Branch if Carry Set | If $\mathrm{C}=1$, branch | REL16 | 3785 | rrrr | 6, 4 |  | - | - | - | - |  | - |
| LBEQ $^{2}$ | Long Branch if Equal to Zero | If $Z=1$, branch | REL16 | 3787 | rrrr | 6, 4 |  | - | - | - | - |  | - |
| LBEV ${ }^{2}$ | Long Branch if EV Set | If $\mathrm{EV}=1$, branch | REL16 | 3791 | rrrr | 6, 4 |  | - - | - | - |  |  | - |
| LBGE $^{2}$ | Long Branch if Greater Than or Equal to Zero | If $\mathrm{N} \oplus \mathrm{V}=0$, branch | REL16 | 378C | rrrr | 6, 4 |  | - | - | - | - | - | - |
| LBGT $^{2}$ | Long Branch if Greater Than Zero | If $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$, branch | REL16 | 378E | rrrr | 6, 4 |  | - - | - | - |  |  | - |
| $\mathrm{LBHI}^{2}$ | Long Branch if Higher | If $C+Z=0$, branch | REL16 | 3782 | rrrr | 6, 4 |  | - - | - | - | - |  | - |
| LBLE $^{2}$ | Long Branch if Less Than or Equal to Zero | If $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$, branch | REL16 | 378F | rrrr | 6, 4 |  | - | - | - | - |  | - |
| LBLS ${ }^{2}$ | Long Branch if Lower or Same | If $C+Z=1$, branch | REL16 | 3783 | rrrr | 6, 4 |  | - | - | - | - |  | - |
| $\mathrm{LBLT}^{2}$ | Long Branch if Less Than Zero | If $\mathrm{N} \oplus \mathrm{V}=1$, branch | REL16 | 378D | rrrr | 6, 4 |  | - - | - | - | - |  | - |
| LBMI $^{2}$ | Long Branch if Minus | If $\mathrm{N}=1$, branch | REL16 | 378B | rrrr | 6, 4 | - | - - | - | - | - | - | - |
| LBMV ${ }^{2}$ | Long Branch if MV Set | If $\mathrm{MV}=1$, branch | REL16 | 3790 | rrrr | 6, 4 | - | - - | - | - | - |  | - |
| LBNE $^{2}$ | Long Branch if Not Equal to Zero | If $Z=0$, branch | REL16 | 3786 | rrrr | 6, 4 | - | - | - | - | - | - | - |
| LBPL ${ }^{2}$ | Long Branch if Plus | If $\mathrm{N}=0$, branch | REL16 | 378A | rrrr | 6, 4 |  | - - | - | - | - |  | - |
| LBRA | Long Branch Always | If $1=1$, branch | REL16 | 3780 | rrrr | 6 | - | - | - | - | - |  | - |
| LBRN | Long Branch Never | If $1=0$, branch | REL16 | 3781 | rrrr | 6 | - | - - | - | - | - | - | - |
| LBSR | Long Branch to Subroutine | $\begin{gathered} \text { Push (PC) } \\ (\text { SK : SP) }-2 \Rightarrow \text { SK : SP } \\ \text { Push (CCR) } \\ (\text { SK : SP) }-2 \Rightarrow \text { SK : SP } \\ \text { (PK : PC) }+ \text { Offset } \Rightarrow \\ \text { PK : PC } \end{gathered}$ | REL16 | 27F9 | rrrr | 10 | - | - - | - | - | - |  | - |
| $L^{\text {LBVC }}{ }^{2}$ | Long Branch if Overflow Clear | If $\mathrm{V}=0$, branch | REL16 | 3788 | rrrr | 6, 4 | - | - | - | - | - | - | - |
| LBVS $^{2}$ | Long Branch if Overflow Set | If $\mathrm{V}=1$, branch | REL16 | 3789 | rrrr | 6, 4 | - | - - | - | - | - | - | - |
| LDAA | Load A | $(\mathrm{M}) \Rightarrow \mathrm{A}$ | $\begin{aligned} & \hline \text { IND8, X } \\ & \text { IND8, Y } \\ & \text { IND8, Z } \\ & \text { IMM8 } \\ & \text { IND16, X } \\ & \text { IND16, Y } \\ & \text { IND16, Z } \\ & \text { EXT } \\ & \text { E, X } \\ & \text { E, Y } \\ & \text { E, Z } \end{aligned}$ | 45 55 65 75 1745 1755 1765 1775 2745 2755 2765 | ff ff ff ii gggg gg g gggg hh II - - - | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 2 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - |  | - | $\Delta$ | $\Delta$ | 0 | - |

Table 35 Instruction Set Summary (Continued)


Table 35 Instruction Set Summary (Continued)

| Mnemonic | Operation | Description | Address | Instruction |  |  | Condition Codes |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Mode | Opcode | Operand | Cycles | S | MV | H ${ }^{\text {EV }}$ | N | Z | V | C |
| LSR | Logical Shift Right |  | $\begin{aligned} & \hline \text { IND8, } X \\ & \text { IND8, } Y \\ & \text { IND8, } Z \\ & \text { IND16, } X \\ & \text { IND16, } Y \\ & \text { IND16, } Z \\ & \text { EXT } \end{aligned}$ | 0 F 1 F 2 F 170 F 171 F 172 F 173 F | ff ff ff gggg gggg gggg $\mathrm{hh} I I$ | $\begin{aligned} & \hline 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ | - | - | - - | 0 | $\Delta$ | $\Delta$ | $\Delta$ |
| LSRA | Logical Shift Right A |  | INH | 370F | - | 2 | - | - | - - | 0 | $\Delta$ | $\Delta$ | $\Delta$ |
| LSRB | Logical Shift Right B |  | INH | 371F | - | 2 |  | - | - - | 0 | $\Delta$ | $\Delta$ | $\Delta$ |
| LSRD | Logical Shift Right D | $0 \rightarrow \xrightarrow[\text { b15 }]{\square---\underset{b 0}{\square}} \rightarrow \square$ | INH | 27FF | - | 2 |  | - | - | 0 | $\Delta$ | $\Delta$ | $\Delta$ |
| LSRE | Logical Shift Right E | $0 \rightarrow \underset{\text { b15 }}{\square---]_{\mathrm{b} 0}} \rightarrow \square$ | INH | 277F | - | 2 | - | - | - | 0 | $\Delta$ | $\Delta$ | $\Delta$ |
| LSRW | Logical Shift Right Word | $0 \rightarrow \xrightarrow[\text { b15 }]{\square--\underset{b 0}{\longrightarrow}} \rightarrow \square$ | $\begin{aligned} & \text { IND16, X } \\ & \text { IND16, Y } \\ & \text { IND16, } Z \\ & \text { EXT } \end{aligned}$ | $\begin{aligned} & 270 F \\ & 271 F \\ & 272 F \\ & 273 F \end{aligned}$ | $\begin{aligned} & \text { gggg } \\ & \text { gggg } \\ & \text { gggg } \\ & \text { hh II } \end{aligned}$ | $\begin{aligned} & \hline 8 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ | - | - | - - | 0 | $\Delta$ | $\Delta$ | $\Delta$ |
| MAC | Multiply and Accumulate Signed 16-Bit Fractions | $\begin{gathered} (\mathrm{HR}) *(\mathrm{IR}) \Rightarrow \mathrm{E}: \mathrm{D} \\ (\mathrm{AM})+(\mathrm{E}: \mathrm{D}) \Rightarrow \mathrm{AM} \\ \text { Qualified }(\mathrm{IX}) \Rightarrow I X \\ \text { Qualified (IY) } \Rightarrow I Y \\ (\mathrm{HR}) \Rightarrow I Z \\ (M: M+1)_{X} \Rightarrow H R \\ (M: M+1)_{Y} \Rightarrow I R \end{gathered}$ | IMM8 | 7B | xoyo | 12 | - | $\Delta$ | - $\Delta$ | - | - | $\Delta$ | - |
| MOVB | Move Byte | $\left(\mathrm{M}_{1}\right) \Rightarrow \mathrm{M}_{2}$ | $\begin{aligned} & \text { IXP to EXT } \\ & \text { EXT to IXP } \\ & \text { EXT to EXT } \end{aligned}$ | $\begin{gathered} 30 \\ 32 \\ \text { 37FE } \end{gathered}$ | ff hh II <br> ff hh II <br> hh II hh II | $\begin{gathered} 8 \\ 8 \\ 10 \end{gathered}$ | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| MOVW | Move Word | $\left(M: M+1_{1}\right) \Rightarrow M: M+1_{2}$ | $\begin{array}{\|l\|} \hline \text { IXP to EXT } \\ \text { EXT to IXP } \\ \text { EXT to EXT } \\ \hline \end{array}$ | $\begin{gathered} \hline 31 \\ 33 \\ 37 \mathrm{FF} \\ \hline \end{gathered}$ | ff hh II ff hh II hh II hh II | $\begin{gathered} \hline 8 \\ 8 \\ 10 \\ \hline \end{gathered}$ | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| MUL | Multiply | (A) * (B) $\Rightarrow \mathrm{D}$ | INH | 3724 | - | 10 | - | - | - - | - | - | - | $\Delta$ |
| NEG | Negate Memory | \$00-(M) $\Rightarrow \mathrm{M}$ | IND8, X <br> IND8, Y <br> IND8, Z <br> IND16, X <br> IND16, Y <br> IND16, Z <br> EXT | $\begin{gathered} \hline 02 \\ 12 \\ 22 \\ 1702 \\ 1712 \\ 1722 \\ 1732 \end{gathered}$ | ff ff ff gggg gggg gggg $\mathrm{hh} I I$ | $\begin{aligned} & \hline 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ | - | - | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| NEGA | Negate A | \$00-(A) $\Rightarrow \mathrm{A}$ | INH | 3702 | - | 2 | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| NEGB | Negate B | \$00-(B) $\Rightarrow{ }^{\text {P }}$ | INH | 3712 | - | 2 | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| NEGD | Negate D | \$0000-(D) $\Rightarrow \mathrm{D}$ | INH | 27F2 | - | 2 | - | - | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| NEGE | Negate E | \$0000-(E) $\Rightarrow \mathrm{E}$ | INH | 2772 | - | 2 | - | - | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| NEGW | Negate Memory Word | $\begin{aligned} & \$ 0000-(M: M+1) \\ & \quad \Rightarrow M: M+1 \end{aligned}$ | $\begin{aligned} & \text { IND16, X } \\ & \text { IND16, } Y \\ & \text { IND16, } Z \\ & \text { EXT } \end{aligned}$ | $\begin{aligned} & 2702 \\ & 2712 \\ & 2722 \\ & 2732 \end{aligned}$ | gggg <br> gggg <br> gggg <br> hh II | $\begin{aligned} & \hline 8 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ | - | - | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| NOP | Null Operation | - | INH | 274C | - | 2 | - | - | - - | - | - | - | - |

Table 35 Instruction Set Summary (Continued)


Table 35 Instruction Set Summary (Continued)

| Mnemonic | Operation | Description | Address | Instruction |  |  | Condition Codes |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Mode | Opcode | Operand | Cycles | S | MV | H EV | N | Z | V | C |
| PULM ${ }^{1}$ | Pull Multiple Registers <br> Mask bits: $\begin{gathered} \begin{array}{c} 0=\mathrm{CCR}[15: 4] \\ 1 \\ =\mathrm{K} \\ 2 \end{array}=\mathrm{IZ} \\ 3=I \mathrm{Y} \\ 4=\mathrm{IX} \\ 5=\mathrm{E} \\ 6=\mathrm{D} \\ 7=\text { (Reserved) } \end{gathered}$ | For mask bits 0 to 7: <br> If mask bit set (SK : SP) $+2 \Rightarrow$ SK : SP <br> Pull register | IMM8 | 35 | ii | $4+2(N+1)$ <br> $\mathrm{N}=$ <br> number of iterations | $\Delta$ | $\Delta$ | $\triangle \Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| PULMAC | Pull MAC State | Stack $\Rightarrow$ MAC Registers | INH | 27B9 | - | 16 |  | - | - - | - | - | - | - |
| RMAC | Repeating Multiply and Accumulate Signed 16-Bit Fractions | $\begin{gathered} \text { Repeat until }(E)<0 \\ (\text { AM })+(H) *(I) \Rightarrow A M \\ \text { Qualified }(I X) \Rightarrow I X ; \\ \text { Qualified }(I Y) \Rightarrow I Y ; \\ (M: M+1)_{X} \Rightarrow H ; \\ (M: M+1)_{Y} \Rightarrow I \\ (E)-1 \Rightarrow E \\ \text { Until }(E)<\$ 0000 \end{gathered}$ | IMM8 | FB | xoyo | $6+12$ <br> per iteration |  | $\Delta$ | - $\Delta$ | - |  |  | - |
| ROL | Rotate Left |  | $\begin{aligned} & \hline \text { IND8, X } \\ & \text { IND8, } Y \\ & \text { IND8, } Z \\ & \text { IND16, } X \\ & \text { IND16, } Y \\ & \text { IND16, } Z \\ & \text { EXT } \end{aligned}$ | 0C $1 C$ $2 C$ $170 C$ $171 C$ $172 C$ $173 C$ | ff ff ff gggg gggg gggg $\mathrm{hh} I I$ | $\begin{aligned} & \hline 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ | - | - | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ROLA | Rotate Left A |  | INH | 370C | - | 2 |  | - | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ROLB | Rotate Left B |  | INH | 371C | - | 2 |  | - | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ROLD | Rotate Left D |  | INH | 27FC | - | 2 |  | - | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ROLE | Rotate Left E |  | INH | 277C | - | 2 |  | - | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ROLW | Rotate Left Word | CCK $\left.\square_{\text {b15 }}^{\square 15}---\right]_{\text {b0 }}$ | $\begin{gathered} \text { IND16, X } \\ \text { IND16, } Y \\ \text { IND16, } Z \\ \text { EXT } \end{gathered}$ | $\begin{aligned} & 270 C \\ & 271 C \\ & 272 C \\ & 273 C \end{aligned}$ | gggg <br> gggg <br> gggg <br> hh II | $\begin{aligned} & \hline 8 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ | - | - | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ROR | Rotate Right Byte |  | $\begin{aligned} & \hline \text { IND8, } X \\ & \text { IND8, } Y \\ & \text { IND8, } Z \\ & \text { IND16, } X \\ & \text { IND16, } Y \\ & \text { IND16, } Z \\ & \text { EXT } \end{aligned}$ | 0 E 1 E 2 E 170 E 171 E 172 E 173 E | ff ff ff gggg gggg gggg $\mathrm{hh} I I$ | $\begin{aligned} & \hline 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ | - |  |  | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| RORA | Rotate Right A |  | INH | 370E | - | 2 | - | - | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| RORB | Rotate Right B | $\rightarrow \stackrel{\square}{\square 7} \mid$ | INH | 371E | - | 2 | - | - | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| RORD | Rotate Right D | $\rightarrow \square_{b 15}^{\square \square---]_{b 0}} \rightarrow \square$ | INH | 27FE | - | 2 | - | - | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| RORE | Rotate Right E |  | INH | 277E | - | 2 | - | - | - - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

Table 35 Instruction Set Summary (Continued)

| Mnemonic | Operation | Description | Address | Instruction |  |  | Condition Codes |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Mode | Opcode | Operand | Cycles | S | MV | H | EV | N | Z | V | C |
| RORW | Rotate Right Word | $\rightarrow \stackrel{\square}{\square 15}---\square_{b 0} \rightarrow \square$ | $\begin{aligned} & \text { IND16, X } \\ & \text { IND16, Y } \\ & \text { IND16, } Z \\ & \text { EXT } \end{aligned}$ | $\begin{aligned} & 270 E \\ & 271 E \\ & 272 E \\ & 273 E \end{aligned}$ | $\begin{aligned} & \text { gggg } \\ & \text { gggg } \\ & \text { gggg } \\ & \text { hh II } \end{aligned}$ | $\begin{aligned} & \hline 8 \\ & 8 \\ & 8 \\ & 8 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| RTI ${ }^{3}$ | Return from Interrupt | $\begin{gathered} (\mathrm{SK}: \mathrm{SP})+2 \Rightarrow \mathrm{SK}: \mathrm{SP} \\ \mathrm{Pull} \mathrm{CCR} \\ (\mathrm{SK}: \mathrm{SP})+2 \Rightarrow \mathrm{SK}: \mathrm{SP} \\ \mathrm{Pull} \mathrm{PC} \\ (\mathrm{PK}: \mathrm{PC})-6 \Rightarrow \mathrm{PK}: \mathrm{PC} \end{gathered}$ | INH | 2777 | - | 12 | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| RTS ${ }^{4}$ | Return from Subroutine | $\begin{gathered} (\mathrm{SK}: \mathrm{SP})+2 \Rightarrow \mathrm{SK}: \mathrm{SP} \\ \mathrm{Pull} \mathrm{PK} \\ (\mathrm{SK}: \mathrm{SP})+2 \Rightarrow \mathrm{SK}: \mathrm{SP} \\ \mathrm{Pull} \mathrm{PC} \\ (\mathrm{PK}: \mathrm{PC})-2 \Rightarrow \mathrm{PK}: \mathrm{PC} \end{gathered}$ | INH | 27F7 | - | 12 | - | - | - | - | - |  |  | - |
| SBA | Subtract B from A | (A) - B$) \Rightarrow \mathrm{A}$ | INH | 370A | - | 2 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SBCA | Subtract with Carry from $A$ | (A) - (M) - C $\Rightarrow$ A | IND8, X <br> IND8, Y <br> IND8, Z <br> IMM8 <br> IND16, X <br> IND16, Y <br> IND16, Z <br> EXT <br> E, X <br> E, Y <br> E, Z | 42 52 62 72 1742 1752 1762 1772 2742 2752 2762 | ff ff ff ii gggg gggg gggg hh II - - - | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 2 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SBCB | Subtract with Carry from B | (B) - (M) - C $\Rightarrow B$ | IND8, X <br> IND8, Y <br> IND8, Z <br> IMM8 <br> IND16, X <br> IND16, Y <br> IND16, Z <br> EXT <br> E, X <br> E, Y <br> E, Z | C2 D2 E2 F2 17C2 17D2 17E2 17F2 27C2 27D2 27E2 | ff ff ff ii gggg gggg gggg hh II - - - | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 2 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SBCD | Subtract with Carry from D |  | $\begin{aligned} & \hline \text { IND8, X } \\ & \text { IND8, } Y \\ & \text { IND8, } Z \\ & \text { IMM16 } \\ & \text { IND16, X } \\ & \text { IND16, Y } \\ & \text { IND16, Z } \\ & \text { EXT } \\ & \text { E, X } \\ & \text { E, Y } \\ & \text { E, Z } \end{aligned}$ | 82 92 A2 $37 B 2$ 37C2 37 D 2 37 E 2 37 F 2 2782 2792 27A2 | ff ff ff $\mathrm{jj} k \mathrm{k}$ gggg gggg gggg hh II - - - | $\begin{aligned} & 6 \\ & 6 \\ & 6 \\ & 4 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - | - |  | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SBCE | Subtract with Carry from E | (E) - (M:M+1)-C $\Rightarrow E$ | IMM16 <br> IND16, X <br> IND16, Y <br> IND16, Z <br> EXT | $\begin{aligned} & 3732 \\ & 3742 \\ & 3752 \\ & 3762 \\ & 3772 \end{aligned}$ | $\begin{aligned} & \hline \text { jj kk } \\ & \text { gggg } \\ & \text { gggg } \\ & \text { gggg } \\ & \text { hh II } \end{aligned}$ | $\begin{aligned} & \hline 4 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SDE | Subtract D from E | (E) - (D) $\Rightarrow \mathrm{E}$ | INH | 2779 | - | 2 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| STAA | Store A | $(\mathrm{A}) \Rightarrow \mathrm{M}$ | IND8, X <br> IND8, Y <br> IND8, Z <br> IND16, $X$ <br> IND16, Y <br> IND16, Z <br> EXT <br> E, X <br> E, Y <br> E, Z | 4 A 5 A 6 A 174 A 175 A 176 A 177 A 274 A 275 A 276 A | ff ff ff gggg gggg gggg hh II - - - | $\begin{aligned} & \hline 4 \\ & 4 \\ & 4 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 4 \\ & 4 \\ & 4 \end{aligned}$ | - | — | - | - | $\Delta$ | $\Delta$ | 0 | - |

Table 35 Instruction Set Summary (Continued)

| Mnemonic | Operation | Description | Address <br> Mode | Instruction |  |  | Condition Codes |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Opcode | Operand | Cycles | S | MV | EV | N | Z | V | C |
| STAB | Store B | (B) $\Rightarrow \mathrm{M}$ | IND8, X | CA | ff | 4 | - - - - |  |  | $\Delta$ | $\Delta$ | 0 - |  |
|  |  |  | IND8, Y | DA | ff | 4 |  |  |  |  |  |  |  |
|  |  |  | IND8, Z | EA | ff | 4 |  |  |  |  |  |  |  |
|  |  |  | IND16, X | 17CA | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | IND16, Y | 17DA | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | IND16, Z | 17EA | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | EXT | 17FA | hh II | 6 |  |  |  |  |  |  |  |
|  |  |  | E, X | 27CA | - | 4 |  |  |  |  |  |  |  |
|  |  |  | E, Y | 27DA | - | 4 |  |  |  |  |  |  |  |
|  |  |  | E, Z | 27EA | - | 4 |  |  |  |  |  |  |  |
| STD | Store D | (D) $\Rightarrow \mathrm{M}: \mathrm{M}+1$ | IND8, X | 8A | ff | 4 | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
|  |  |  | IND8, Y | 9A | ff | 4 |  |  |  |  |  |  |  |
|  |  |  | IND8, Z | AA | ff | 4 |  |  |  |  |  |  |  |
|  |  |  | IND16, X | 37CA | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | IND16, Y | 37DA | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | IND16, Z | 37EA | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | EXT | 37FA | hh II | 6 |  |  |  |  |  |  |  |
|  |  |  | E, X | 278A | - | 6 |  |  |  |  |  |  |  |
|  |  |  | E, Y | 279A | - | 6 |  |  |  |  |  |  |  |
|  |  |  | E, Z | 27AA | - | 6 |  |  |  |  |  |  |  |
| STE | Store E | (E) $\Rightarrow \mathrm{M}: \mathrm{M}+1$ | IND16, X | 374A | gggg | 6 | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
|  |  |  | IND16, Y | 375A | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | IND16, Z | 376A | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | EXT | 377A | hh II | 6 |  |  |  |  |  |  |  |
| STED | Store Concatenated D and E | $\begin{gathered} (E) \Rightarrow M: M+1 \\ (D) \Rightarrow M+2: M+3 \end{gathered}$ | EXT | 2773 | hh II | 8 | - | - |  | - | - | - | - |
| STS | Store Stack Pointer | $(S P) \Rightarrow M: M+1$ | IND8, X | 8F | ff | 4 | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
|  |  |  | IND8, Y | 9F | $f f$ | 4 |  |  |  |  |  |  |  |
|  |  |  | IND8, Z | AF | ff | 4 |  |  |  |  |  |  |  |
|  |  |  | IND16, X | 178F | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | IND16, Y | 179F | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | IND16, Z | 17AF | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | EXT | 17BF | hh II | 6 |  |  |  |  |  |  |  |
| STX | Store IX | $(I X) \Rightarrow M: M+1$ | IND8, X | 8C | ff | 4 | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
|  |  |  | IND8, Y | 9 C | ff | 4 |  |  |  |  |  |  |  |
|  |  |  | IND8, Z | AC | ff | 4 |  |  |  |  |  |  |  |
|  |  |  | IND16, X | 178C | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | IND16, Y | 179C | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | IND16, Z | 17AC | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | EXT | 17BC | hh II | 6 |  |  |  |  |  |  |  |
| STY | Store IY | $(\mathrm{Y}) \Rightarrow \mathrm{M}: \mathrm{M}+1$ | IND8, X | 8D | $f$ | 4 | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
|  |  |  | IND8, Y | 9D | ff | 4 |  |  |  |  |  |  |  |
|  |  |  | IND8, Z | AD | ff | 4 |  |  |  |  |  |  |  |
|  |  |  | IND16, X | 178D | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | IND16, Y | 179D | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | IND16, Z | 17AD | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | EXT | 17BD | hh II | 6 |  |  |  |  |  |  |  |
| STZ | Store Z | $(\mathrm{Z}) \Rightarrow \mathrm{M}: \mathrm{M}+1$ | IND8, X | 8E | $f f$ | 4 | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
|  |  |  | IND8, Y | 9 E | $f f$ | 4 |  |  |  |  |  |  |  |
|  |  |  | IND8, Z | AE | ff | 4 |  |  |  |  |  |  |  |
|  |  |  | IND16, X | 178E | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | IND16, Y | 179E | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | IND16, Z | 17AE | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | EXT | 17BE | hh II | 6 |  |  |  |  |  |  |  |
| SUBA | Subtract from A | (A) - M$) \Rightarrow \mathrm{A}$ | IND8, X | 40 | ff | 6 | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
|  |  |  | IND8, Y | 50 | ff | 6 |  |  |  |  |  |  |  |
|  |  |  | IND8, Z | 60 | ff | 6 |  |  |  |  |  |  |  |
|  |  |  | IMM8 | 70 | ii | 2 |  |  |  |  |  |  |  |
|  |  |  | IND16, X | 1740 | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | IND16, Y | 1750 | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | IND16, Z | 1760 | gggg | 6 |  |  |  |  |  |  |  |
|  |  |  | EXT | 1770 | hh II | 6 |  |  |  |  |  |  |  |
|  |  |  | E, X | 2740 | - | 6 |  |  |  |  |  |  |  |
|  |  |  | E, Y | 2750 | - | 6 |  |  |  |  |  |  |  |
|  |  |  | E, Z | 2760 | - | 6 |  | - |  |  |  |  |  |

Table 35 Instruction Set Summary (Continued)

| Mnemonic | Operation | Description | Address | Instruction |  |  | Condition Codes |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Mode | Opcode | Operand | Cycles | S | MV | H | EV | N | Z | V | C |
| SUBB | Subtract from B | (B) - M$) \Rightarrow \mathrm{B}$ | IND8, X <br> IND8, Y <br> IND8, Z <br> IMM8 <br> IND16, X <br> IND16, $Y$ <br> IND16, Z <br> EXT <br> E, X <br> E, Y <br> E, Z | C0 D0 E0 F0 17C0 17D0 17E0 17F0 $27 C 0$ $27 D 0$ $27 E 0$ | ff <br> ff <br> ff <br> ii <br> gggg <br> gggg <br> gggg <br> hh II <br> - <br> - | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 2 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SUBD | Subtract from D | (D) - (M : M + 1) $\Rightarrow D$ | IND8, X <br> IND8, Y <br> IND8, Z <br> IMM16 <br> IND16, X <br> IND16, Y <br> IND16, Z <br> EXT <br> E, X <br> E, Y <br> E, Z | 80 90 A0 $37 B 0$ $37 C 0$ $37 D 0$ $37 E 0$ $37 F 0$ 2780 2790 $27 A 0$ | ff <br> ff <br> ff <br> $\mathrm{jj} k \mathrm{k}$ <br> gggg <br> gggg <br> gggg <br> $\mathrm{hh} I I$ <br> - <br> - <br> - | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 4 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SUBE | Subtract from E | (E) - (M : M + 1) $\Rightarrow E$ | $\begin{aligned} & \text { IMM16 } \\ & \text { IND16, } X \\ & \text { IND16, Y } \\ & \text { IND16, Z } \\ & \text { EXT } \end{aligned}$ | $\begin{aligned} & 3730 \\ & 3740 \\ & 3750 \\ & 3760 \\ & 3770 \end{aligned}$ | jj kk gggg gggg gggg hh II | $\begin{aligned} & 4 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SWI | Software Interrupt | $\left(\begin{array}{c} (\mathrm{PK}: \mathrm{PC})+\$ 0002 \Rightarrow \mathrm{PK}: \mathrm{PC} \\ \text { Push }(\mathrm{PC}) \\ (\mathrm{SK}: \mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SK}: \mathrm{SP} \\ \text { Push }(\mathrm{CCR}) \\ (\mathrm{SK}: \mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SK}: \mathrm{SP} \\ \$ 0 \Rightarrow \mathrm{PK} \\ \text { SWI Vector } \Rightarrow \mathrm{PC} \end{array}\right.$ | INH | 3720 | - | 16 |  | - | - | - | - | - | - | - |
| SXT | Sign Extend B into A | $\begin{gathered} \text { If } B 7=1 \\ \text { then } \$ F F \Rightarrow A \\ \text { else } \$ 00 \Rightarrow A \\ \hline \end{gathered}$ | INH | 27F8 | - | 2 | - | - | - | - | $\Delta$ | $\Delta$ | - | - |
| TAB | Transfer A to B | $(\mathrm{A}) \Rightarrow \mathrm{B}$ | INH | 3717 | - | 2 | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| TAP | Transfer A to CCR | $(\mathrm{A}[7: 0]) \Rightarrow \operatorname{CCR}[15: 8]$ | INH | 37FD | - | 4 | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| TBA | Transfer B to A | (B) $\Rightarrow \mathrm{A}$ | INH | 3707 | - | 2 | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| TBEK | Transfer B to EK | $(\mathrm{B}[3: 0]) \Rightarrow \mathrm{EK}$ | INH | 27FA | - | 2 | - | - | - | - | - | - | - | - |
| TBSK | Transfer B to SK | $(\mathrm{B}[3: 0]) \Rightarrow \mathrm{SK}$ | INH | 379F | - | 2 | - | - | - | - | - | - | - | - |
| TBXK | Transfer B to XK | (B[3:0]) $\Rightarrow \mathrm{XK}$ | INH | 379C | - | 2 | - | - | - | - | - | - | - | - |
| TBYK | Transfer B to YK | (B[3:0]) $\Rightarrow \mathrm{YK}$ | INH | 379D | - | 2 | - | - | - | - | - | - | - | - |
| TBZK | Transfer B to ZK | (B[3:0]) $\Rightarrow \mathrm{ZK}$ | INH | 379E | - | 2 | - | - | - | - | - | - | - | - |
| TDE | Transfer D to E | (D) $\Rightarrow \mathrm{E}$ | INH | 277B | - | 2 | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| TDMSK | Transfer D to XMSK : YMSK | $\begin{gathered} (D[15: 8]) \Rightarrow X \text { MASK } \\ (D[7: 0]) \Rightarrow \text { Y MASK } \end{gathered}$ | INH | 372F | - | 2 | - | - | - | - | - | - | - | - |
| TDP ${ }^{1}$ | Transfer D to CCR | $(\mathrm{D}) \Rightarrow \mathrm{CCR}[15: 4]$ | INH | 372D | - | 4 | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| TED | Transfer E to D | (E) $\Rightarrow$ D | INH | 27FB | - | 2 | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| TEDM | $\begin{gathered} \text { Transfer E and D to } \\ \text { AM[31:0] } \\ \text { Sign Extend AM } \end{gathered}$ | $\begin{gathered} (\mathrm{E}) \Rightarrow \text { AM[31:16] } \\ (\mathrm{D}) \Rightarrow A M[15: 0] \\ A M[35: 32]=A M 31 \end{gathered}$ | INH | 27B1 | - | 4 | - | 0 | - | 0 | - | - | - | - |
| TEKB | Transfer EK to B | $\begin{gathered} (\mathrm{EK}) \Rightarrow \mathrm{B}[3: 0] \\ \$ 0 \Rightarrow \mathrm{~B}[7: 4] \end{gathered}$ | INH | 27BB | - | 2 | - | - | - | - | - | - | - | - |
| TEM | Transfer E to AM[31:16] Sign Extend AM Clear AM LSB | $\begin{gathered} (E) \Rightarrow A M[31: 16] \\ \$ 00 \Rightarrow A M[15: 0] \\ A M[35: 32]=A M 31 \end{gathered}$ | INH | 27B2 | - | 4 | - | 0 | - | 0 | - | - | - | - |
| TMER | Transfer Rounded AM to E | ```Rounded (AM) = Temp If (SM \bullet (EV + MV)) then Saturation Value }=>\textrm{E else Temp[31:16] => E``` | INH | 27B4 | - | 6 | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | - | - |

Table 35 Instruction Set Summary (Continued)

| Mnemonic | Operation | Description | Address | Instruction |  |  | Condition Codes |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Mode | Opcode | Operand | Cycles | S | MV | H | EV | N | Z | V | C |
| TMET | Transfer Truncated AM to E | If (SM• (EV + MV)) then Saturation Value $\Rightarrow E$ else $A M[31: 16] \Rightarrow E$ | INH | 27B5 | - | 2 |  | - | - | - | $\Delta$ | $\Delta$ | - | - |
| TMXED | $\begin{gathered} \text { Transfer AM to } \\ \text { IX: E:D } \end{gathered}$ | $\begin{gathered} \text { AM[35:32] } \Rightarrow \mathrm{IX}[3: 0] \\ \text { AM35 } \Rightarrow \mathrm{IX}[15: 4] \\ \text { AM }[31: 16] \Rightarrow \mathrm{E} \\ \text { AM }[15: 0] \Rightarrow \mathrm{D} \end{gathered}$ | INH | 27B3 | - | 6 |  | - | - | - | - |  |  | - |
| TPA | Transfer CCR to A | $(\mathrm{CCR}[15: 8]) \Rightarrow \mathrm{A}$ | INH | 37FC | - | 2 | - | - | - | - | - | - | - | - |
| TPD | Transfer CCR to D | (CCR) $\Rightarrow \mathrm{D}$ | INH | 372C | - | 2 | - | - | - | - | - | - | - | - |
| TSKB | Transfer SK to B | $\begin{gathered} (\mathrm{SK}) \Rightarrow \mathrm{B}[3: 0] \\ \$ 0 \Rightarrow \mathrm{~B}[7: 4] \end{gathered}$ | INH | 37AF | - | 2 |  | - | - | - | - | - | - | - |
| TST | Test Byte Zero or Minus | (M) - \$00 | $\begin{gathered} \text { IND8, } \mathrm{X} \\ \text { IND8, } \mathrm{Y} \\ \text { IND8, } \mathrm{Z} \\ \text { IND16, } \mathrm{X} \\ \text { IND16, Y } \\ \text { IND16, Z } \\ \text { EXT } \end{gathered}$ | 06 16 26 1706 1716 1726 1736 | ff ff ff gggg gggg gggg hh II | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ |  | - | - | - | $\Delta$ | $\Delta$ | 0 | 0 |
| TSTA | Test A for Zero or Minus | (A) - \$00 | INH | 3706 | - | 2 |  | - |  | - | $\Delta$ | $\Delta$ | 0 | 0 |
| TSTB | Test B for Zero or Minus | (B) - \$00 | INH | 3716 | - | 2 |  | - |  | - | $\Delta$ | $\Delta$ | 0 | 0 |
| TSTD | Test D for Zero or Minus | (D) - \$0000 | INH | 27F6 | - | 2 |  | - |  | - | $\Delta$ | $\Delta$ | 0 | 0 |
| TSTE | Test E for Zero or Minus | (E) - \$0000 | INH | 2776 | - | 2 |  | - |  | - | $\Delta$ | $\Delta$ | 0 | 0 |
| TSTW | Test for Zero or Minus Word | $(\mathrm{M}: \mathrm{M}+1)-\$ 0000$ | $\begin{gathered} \hline \text { IND16, X } \\ \text { IND16, } Y \\ \text { IND16, } Z \\ \text { EXT } \end{gathered}$ | $\begin{aligned} & 2706 \\ & 2716 \\ & 2726 \\ & 2736 \end{aligned}$ | $\begin{aligned} & \hline \text { gggg } \\ & \text { gggg } \\ & \text { gggg } \\ & \text { hh II } \end{aligned}$ | $\begin{aligned} & \hline 6 \\ & 6 \\ & 6 \\ & 6 \end{aligned}$ |  | - |  | - | $\Delta$ | $\Delta$ | 0 | 0 |
| TSX | Transfer SP to IX | (SK : SP) + \$0002 $\Rightarrow$ XK : IX | INH | 274F | - | 2 | - | - | - | - | - | - | - | - |
| TSY | Transfer SP to IY | (SK : SP) + \$0002 $\Rightarrow$ YK : IY | INH | 275F | - | 2 | - | - | - | - | - | - | - | - |
| TSZ | Transfer SP to IZ | (SK : SP) + \$0002 $\Rightarrow$ ZK : IZ | INH | 276F | - | 2 | - | - | - | - | - | - | - | - |
| TXKB | Transfer XK to B | $\begin{gathered} (\mathrm{XK}) \Rightarrow \mathrm{B}[3: 0] \\ \$ 0 \Rightarrow \mathrm{~B}[7: 4] \end{gathered}$ | INH | 37AC | - | 2 | - |  |  | - | - | - | - | - |
| TXS | Transfer IX to SP | (XK : IX) - \$0002 $\Rightarrow$ SK : SP | INH | 374E | - | 2 | - | - | - | - | - | - | - | - |
| TXY | Transfer IX to IY | $(\mathrm{XK}: \mathrm{IX}) \Rightarrow \mathrm{YK}: \mathrm{IY}$ | INH | 275C | - | 2 | - | - | - | - | - | - | - | - |
| TXZ | Transfer IX to IZ | $(\mathrm{XK}: \mathrm{IX}) \Rightarrow \mathrm{ZK}: \mathrm{IZ}$ | INH | 276C | - | 2 | - | - | - | - | - | - | - | - |
| TYKB | Transfer YK to B | $\begin{gathered} (\mathrm{YK}) \Rightarrow \mathrm{B}[3: 0] \\ \$ 0 \Rightarrow \mathrm{~B}[7: 4] \end{gathered}$ | INH | 37AD | - | 2 | - | - | - | - | - | - | - | - |
| TYS | Transfer IY to SP | (YK : IY) - \$0002 $\Rightarrow$ SK : SP | INH | 375E | - | 2 | - | - | - | - | - | - | - | - |
| TYX | Transfer IY to IX | $(\mathrm{YK}: \mathrm{IY}) \Rightarrow \mathrm{XK}: \mathrm{IX}$ | INH | 274D | - | 2 | - | - | - | - | - | - | - | - |
| TYZ | Transfer IY to IZ | $(\mathrm{YK}: \mathrm{IY}) \Rightarrow \mathrm{ZK}: \mathrm{IZ}$ | INH | 276D | - | 2 | - | - | - | - | - | - | - | - |
| TZKB | Transfer ZK to B | $\begin{gathered} (\mathrm{ZK}) \Rightarrow \mathrm{B}[3: 0] \\ \$ 0 \Rightarrow \mathrm{~B}[7: 4] \end{gathered}$ | INH | 37AE | - | 2 | - | - | - | - | - | - | - | - |
| TZS | Transfer IZ to SP | (ZK : IZ) - \$0002 $\Rightarrow$ SK : SP | INH | 376E | - | 2 | - | - | - | - | - | - | - | - |
| TZX | Transfer IZ to IX | $(Z \mathrm{~K}: \mathrm{IZ}) \Rightarrow \mathrm{XK}$ : IX | INH | 274E | - | 2 | - | 一 | - | - | - | - | - | - |
| TZY | Transfer IZ to IY | $(\mathrm{ZK}: \mathrm{IZ}) \Rightarrow \mathrm{ZK}:$ IY | INH | 275E | 一 | 2 | - | - | - | - | - | - | - | - |

Table 35 Instruction Set Summary (Continued)

| Mnemonic | Operation | Description | Address | Instruction |  |  | Condition Codes |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Mode | Opcode | Operand | Cycles | S | MV | H | EV | N | Z | V | C |
| WAI | Wait for Interrupt | WAIT | INH | 27F3 | - | 8 | - | - | - | - | - | - | - | - |
| XGAB | Exchange A with B | $(\mathrm{A}) \Leftrightarrow(\mathrm{B})$ | INH | 371A | - | 2 | - | - | - | - | - | - | - | - |
| XGDE | Exchange D with E | (D) $\Leftrightarrow(\mathrm{E})$ | INH | 277A | - | 2 | - | - | - | - | - | - | - | - |
| XGDX | Exchange D with IX | (D) $\Leftrightarrow(\mathrm{IX})$ | INH | 37CC | - | 2 | - | - | - | - | - | - | - | - |
| XGDY | Exchange D with IY | (D) $\Leftrightarrow(\mathrm{IY})$ | INH | 37DC | - | 2 | - | - | - | - | - | - | - | - |
| XGDZ | Exchange D with IZ | (D) $\Leftrightarrow(\mathrm{I})$ | INH | 37EC | - | 2 | - | - | - | - | - | - | - | - |
| XGEX | Exchange E with IX | (E) $\Leftrightarrow$ (IX) | INH | 374C | - | 2 | - | - | - | - | - | - | - | - |
| XGEY | Exchange E with IY | (E) $\Leftrightarrow(\mathrm{IY})$ | INH | 375C | - | 2 | - | - | - | - | - | - | - | - |
| XGEZ | Exchange E with IZ | (E) $\Leftrightarrow(\mathrm{IZ})$ | INH | 376C | - | 2 | - | - | - | - | - | - | - | - |

1. CCR[15:4] change according to results of operation. The PK field is not affected.
2. Cycle times for conditional branches are shown in "taken, not taken" order.
3. CCR[15:0] change according to copy of CCR pulled from stack.
4. PK field changes according to state pulled from stack. The rest of the CCR is not affected.

Table 36 Instruction Set Abbreviations and Symbols

$$
\begin{aligned}
& \text { A - Accumulator A } \\
& \text { AM - Accumulator M } \\
& \text { B - Accumulator B } \\
& \text { CCR - Condition code register } \\
& \text { D - Accumulator D } \\
& \text { E - Accumulator E } \\
& \text { EK — Extended addressing extension field } \\
& \text { IR — MAC multiplicand register } \\
& \text { HR — MAC multiplier register } \\
& \text { IX — Index register } X \\
& \text { IY - Index register } Y \\
& \text { IZ - Index register Z } \\
& \text { K - Address extension register } \\
& \text { PC - Program counter } \\
& \text { PK — Program counter extension field } \\
& \text { SK — Stack pointer extension field } \\
& \text { SL - Multiply and accumulate sign latch } \\
& \text { SP - Stack pointer } \\
& \text { XK — Index register } \mathrm{X} \text { extension field } \\
& \text { YK — Index register Y extension field } \\
& \text { ZK — Index register } Z \text { extension field } \\
& \text { XMSK — Modulo addressing index register X mask } \\
& \text { YMSK — Modulo addressing index register Y mask } \\
& \text { S - Stop disable control bit } \\
& \text { MV - AM overflow indicator } \\
& \text { H - Half carry indicator } \\
& \text { EV - AM extended overflow indicator } \\
& \mathrm{N} \text { - Negative indicator } \\
& \text { Z — Zero indicator } \\
& \text { V — Two's complement overflow indicator } \\
& \text { C - Carry/borrow indicator } \\
& \text { IP — Interrupt priority field } \\
& \text { SM — Saturation mode control bit } \\
& \text { PK - Program counter extension field } \\
& \text { ——Bit not affected } \\
& \Delta \text { — Bit changes as specified } \\
& 0 \text { - Bit cleared } \\
& 1 \text { - Bit set } \\
& \text { M - Memory location used in operation } \\
& \text { R - Result of operation } \\
& \text { S - Source data } \\
& \text { + - Addition } \\
& \text { - - Subtraction or negation (two's complement) } \\
& \text { * - Multiplication } \\
& \text { / - Division } \\
& \text { > - Greater } \\
& \text { < - Less } \\
& =- \text { Equal } \\
& \geq \text { - Equal or greater } \\
& \leq \text { - Equal or less } \\
& \neq- \text { Not equal }
\end{aligned}
$$

X - Register used in operation
M - Address of one memory byte
$\mathrm{M}+1$ - Address of byte at $\mathrm{M}+\$ 0001$
$M: M+1$ - Address of one memory word
(...)X - Contents of address pointed to by IX
(...) Y - Contents of address pointed to by IY
(...) $Z$ - Contents of address pointed to by IZ

E, X — IX with E offset
$E, Y-I Y$ with $E$ offset
$E, Z-I Z$ with $E$ offset
EXT - Extended
EXT20 - 20-bit extended
IMM8 - 8-bit immediate
IMM16 - 16-bit immediate
IND8, X - IX with unsigned 8-bit offset
IND8, Y — IY with unsigned 8-bit offset
IND8, $Z-I Z$ with unsigned 8 -bit offset
IND16, X — IX with signed 16-bit offset
IND16, Y — IY with signed 16-bit offset
IND16, $Z-I Z$ with signed 16 -bit offset
IND20, X — IX with signed 20-bit offset
IND20, Y — IY with signed 20-bit offset
IND20, Z — IZ with signed 20-bit offset
INH — Inherent
IXP — Post-modified indexed
REL8 - 8-bit relative
REL16 - 16-bit relative
b - 4-bit address extension
ff - 8-bit unsigned offset
gggg - 16-bit signed offset
hh - High byte of 16-bit extended address
ii - 8-bit immediate data
jj — High byte of 16-bit immediate data
kk - Low byte of 16 -bit immediate data
II - Low byte of 16 -bit extended address
mm - 8-bit mask
mmmm - 16-bit mask
rr - 8-bit unsigned relative offset
rrrr - 16-bit signed relative offset
xo — MAC index register $X$ offset
yo - MAC index register $Y$ offset
z - 4-bit zero extension

- — AND
+     - Inclusive OR (OR)
$\oplus$ - Exclusive OR (EOR)
$\overline{\text { NOT }}$ - Complementation
: - Concatenation
$\Rightarrow$ - Transferred
$\Leftrightarrow$ - Exchanged
$\pm$ - Sign bit; also used to show tolerance
" - Sign extension
$\%$ - Binary value
\$ - Hexadecimal value


### 4.7 Exceptions

An exception is an event that preempts normal instruction process. Exception processing makes the transition from normal instruction execution to execution of a routine that deals with an exception.

Each exception has an assigned vector that points to an associated handler routine. Exception processing includes all operations required to transfer control to a handler routine, but does not include execution of the handler routine itself. Keep the distinction between exception processing and execution of an exception handler in mind while reading this section.

### 4.7.1 Exception Vectors

An exception vector is the address of a routine that handles an exception. Exception vectors are contained in a data structure called the exception vector table, which is located in the first 512 bytes of bank 0 . Refer to Table 37 for the exception vector table.

All vectors except the reset vector consist of one word and reside in data space. The reset vector consists of four words that reside in program space. There are 52 predefined or reserved vectors, and 200 user-defined vectors.

Each vector is assigned an 8 -bit number. Vector numbers for some exceptions are generated by external devices; others are supplied by the processor. There is a direct mapping of vector number to vector table address. The processor left shifts the vector number one place (multiplies by two) to convert it to an address.

Table 37 Exception Vector Table

| Vector Number | Vector Address | Address Space | Type of Exception |
| :---: | :---: | :---: | :---: |
| 0 | 0000 | P | Reset - Initial ZK, SK, and PK |
|  | 0002 | P | Reset - Initial PC |
|  | 0004 | P | Reset - Initial SP |
|  | 0006 | P | Reset - Initial IZ (Direct Page) |
| 4 | 0008 | D | Breakpoint |
| 5 | 000A | D | Bus Error |
| 6 | 000C | D | Software Interrupt |
| 7 | 000E | D | Illegal Instruction |
| 8 | 0010 | D | Division by Zero |
| $9-\mathrm{E}$ | 0012-001C | D | Unassigned, Reserved |
| F | 001E | D | Uninitialized Interrupt |
| 10 | 0020 | D | Unassigned, Reserved |
| 11 | 0022 | D | Level 1 Interrupt Autovector |
| 12 | 0024 | D | Level 2 Interrupt Autovector |
| 13 | 0026 | D | Level 3 Interrupt Autovector |
| 14 | 0028 | D | Level 4 Interrupt Autovector |
| 15 | 002A | D | Level 5 Interrupt Autovector |
| 16 | 002C | D | Level 6 Interrupt Autovector |
| 17 | 002E | D | Level 7 Interrupt Autovector |
| 18 | 0030 | D | Spurious Interrupt |
| 19-37 | 0032-006E | D | Unassigned, Reserved |
| 38 - FF | 0070 - 01FE | D | User-Defined Interrupts |

### 4.7.2 Exception Stack Frame

During exception processing, the contents of the program counter and condition code register are stacked at a location pointed to by SK:SP. Unless it is altered during exception processing, the stacked PK:PC value is the address of the next instruction in the current instruction stream, plus $\$ 0006$. Figure 12 shows the exception stack frame.


Figure 12 Exception Stack Frame Format

### 4.7.3 Exception Processing Sequence

Exception processing is performed in four phases.
A. Priority of all pending exceptions is evaluated, and the highest priority exception is processed first.
B. Processor state is stacked, then the CCR PK extension field is cleared.
C. An exception vector number is acquired and converted to a vector address.
D. The content of the vector address is loaded into the PC, and the processor jumps to the exception handler routine.

There are variations within each phase for differing types of exceptions. However, all vectors but the reset vectors contain 16 -bit addresses, and the PK field is cleared. Exception handlers must be located within bank 0 or vectors must point to a jump table.

### 4.7.4 Types of Exceptions

Exceptions can be either internally or externally generated. External exceptions, which are defined as asynchronous, include interrupts, bus errors (BERR), breakpoints (BKPT), and resets (RESET). Internal exceptions, which are defined as synchronous, include the software interrupt (SWI) instruction, the background (BGND) instruction, illegal instruction exceptions, and the divide-by-zero exception.

### 4.7.4.1 Asynchronous Exceptions

Asynchronous exceptions occur without reference to CPU16 or IMB clocks, but exception processing is synchronized. For all asynchronous exceptions but RESET, exception processing begins at the first instruction boundary following recognition of an exception.

Because of pipelining, the stacked return PK : PC value for all asynchronous exceptions, other than reset, is equal to the address of the next instruction in the current instruction stream plus $\$ 0006$. The RTI instruction, which must terminate all exception handler routines, subtracts $\$ 0006$ from the stacked value to resume execution of the interrupted instruction stream.

### 4.7.4.2 Synchronous Exceptions

Synchronous exception processing is part of an instruction definition. Exception processing for synchronous exceptions is always completed, and the first instruction of the handler routine is always executed, before interrupts are detected.

Because of pipelining, the value of PK : PC at the time a synchronous exception executes is equal to the address of the instruction that causes the exception plus $\$ 0006$. Because RTI always subtracts $\$ 0006$ upon return, the stacked PK : PC must be adjusted by the instruction that caused the exception so that execution resumes with the following instruction. For this reason, $\$ 0002$ is added to the PK : PC value before it is stacked.

### 4.7.5 Multiple Exceptions

Each exception has a hardware priority based upon its relative importance to system operation. Asynchronous exceptions have higher priorities than synchronous exceptions. Exception processing for multiple exceptions is completed by priority, from highest to lowest. Priority governs the order in which exception processing occurs, not the order in which exception handlers are executed.

Unless a bus error, a breakpoint, or a reset occurs during exception processing, the first instruction of all exception handler routines is guaranteed to execute before another exception is processed. Because interrupt exceptions have higher priority than synchronous exceptions, the first instruction in an interrupt handler are executed before other interrupts are sensed.

Bus error, breakpoint, and reset exceptions that occur during exception processing of a previous exception are processed before the first instruction of that exception's handler routine. The converse is not true. If an interrupt occurs during bus error exception processing, for example, the first instruction of the exception handler is executed before interrupts are sensed. This permits the exception handler to mask interrupts during execution.

### 4.7.6 RTI Instruction

The return-from-interrupt instruction (RTI) must be the last instruction in all exception handlers except the RESET handler. RTI pulls the exception stack frame that was pushed onto the system stack during exception processing, and restores processor state. Normal program flow resumes at the address of the instruction that follows the last instruction executed before exception processing began.

RTI is not used in the RESET handler because RESET initializes the stack pointer and does not create a stack frame.

## 5 Analog-to-Digital Converter Module

The analog-to-digital converter module (ADC) is a unipolar, successive-approximation converter with eight modes of operation. It has selectable 8 - or 10-bit resolution. Monotonicity is guaranteed in both modes.

ADC module conversion functions can be grouped into three basic subsystems: an analog front end, a digital control section, and result storage. In addition, the six analog inputs can be used as a general-purpose digital input (port ADA), provided signals are within logic level specification.

Figure 13 shows a block diagram of the ADC converter module.

### 5.1 Analog Subsystem

The analog front end consists of a multiplexer, a buffer amplifier, a resistor-capacitor array, and a high-gain comparator. The multiplexer selects one of six internal or six external signal sources for conversion. The buffer amplifier protects the input channel from the relatively large capacitance of the resistor capacitor ( RC ) array. The RC array performs two functions: it acts as a sample/hold circuit, and it provides the digital-to-analog comparison output necessary for successive approximation conversion. The comparator indicates whether each successive output of the RC array is higher or lower than the sampled input.

### 5.2 Digital Control Subsystem

The digital control section includes conversion sequence control logic, channel and reference select logic, a successive approximation register, eight result registers, a port data register, and control/ status registers. It controls the multiplexer and the output of the RC array during the sample and conversion periods, stores the results of comparison in the successive-approximation register, and transfers the result to a result register.

### 5.3 Bus Interface Subsystem

The ADC bus interface unit contains logic necessary to interface the ADC to the intermodule bus. The ADC is designed to act as a slave device on the bus. The interface must respond with appropriate bus cycle termination signals and supply appropriate interface timing to the other submodules.


Figure 13 Analog-to-Digital Converter Block Diagram

### 5.4 ADC Address Map

Table 38 shows the ADC address map.

Table 38 ADC Address Map

| Address | 15 | 8 | 7 |
| :---: | :---: | :---: | :---: |
| \$YFF700 ${ }^{1}$ | ADC MODULE CONFIGURATION REGISTER (ADCMCR) |  |  |
| \$YFF702 | ADC TEST REGISTER (ADCTEST) |  |  |
| \$YFF704 | RESERVED |  |  |
| \$YFF706 | PORT ADA DATA (PORTADA) |  |  |
| \$YFF708 | RESERVED |  |  |
| \$YFF70A | ADC CONTROL REGISTER 0 (ADCTLO) |  |  |
| \$YFF70C | ADC CONTROL REGISTER 1 (ADCTL1) |  |  |
| \$YFF70E | ADC STATUS REGISTER (ADSTAT) |  |  |
| \$YFF710 | RIGHT-JUSTIFIED UNSIGNED ADC RESULT REGISTER 0 (RJURRO) |  |  |
| \$YFF712 | RIGHT-JUSTIFIED UNSIGNED ADC RESULT REGISTER 1 (RJURR1) |  |  |
| \$YFF714 | RIGHT-JUSTIFIED UNSIGNED ADC RESULT REGISTER 2 (RJURR2) |  |  |
| \$YFF716 | RIGHT-JUSTIFIED UNSIGNED ADC RESULT REGISTER 3 (RJURR3) |  |  |
| \$YFF718 | RIGHT-JUSTIFIED UNSIGNED ADC RESULT REGISTER 4 (RJURR4) |  |  |
| \$YFF71A | RIGHT-JUSTIFIED UNSIGNED ADC RESULT REGISTER 5 (RJURR5) |  |  |
| \$YFF71C | RIGHT-JUSTIFIED UNSIGNED ADC RESULT REGISTER 6 (RJURR6) |  |  |
| \$YFF71E | RIGHT-JUSTIFIED UNSIGNED ADC RESULT REGISTER 7 (RJURR7) |  |  |
| \$YFF720 | LEFT-JUSTIFIED SIGNED ADC RESULT REGISTER 0 (LJSRR0) |  |  |
| \$YFF722 | LEFT-JUSTIFIED SIGNED ADC RESULT REGISTER 1 (LJSRR1) |  |  |
| \$YFF724 | LEFT-JUSTIFIED SIGNED ADC RESULT REGISTER 2 (LJSRR2) |  |  |
| \$YFF726 | LEFT-JUSTIFIED SIGNED ADC RESULT REGISTER 3 (LJSRR3) |  |  |
| \$YFF728 | LEFT-JUSTIFIED SIGNED ADC RESULT REGISTER 4 (LJSRR4) |  |  |
| \$YFF72A | LEFT-JUSTIFIED SIGNED ADC RESULT REGISTER 5 (LJSRR5) |  |  |
| \$YFF72C | LEFT-JUSTIFIED SIGNED ADC RESULT REGISTER 6 (LJSRR6) |  |  |
| \$YFF72E | LEFT-JUSTIFIED SIGNED ADC RESULT REGISTER 7 (LJSRR7) |  |  |
| \$YFF730 | LEFT-JUSTIFIED UNSIGNED ADC RESULT REGISTER 0 (LJURRO) |  |  |
| \$YFF732 | LEFT-JUSTIFIED UNSIGNED ADC RESULT REGISTER 1 (LJURR1) |  |  |
| \$YFF734 | LEFT-JUSTIFIED UNSIGNED ADC RESULT REGISTER 2 (LJURR2) |  |  |
| \$YFF736 | LEFT-JUSTIFIED UNSIGNED ADC RESULT REGISTER 3 (LJURR3) |  |  |
| \$YFF738 | LEFT-JUSTIFIED UNSIGNED ADC RESULT REGISTER 4 (LJURR4) |  |  |
| \$YFF73A | LEFT-JUSTIFIED UNSIGNED ADC RESULT REGISTER 5 (LJURR5) |  |  |
| \$YFF73C | LEFT-JUSTIFIED UNSIGNED ADC RESULT REGISTER 6 (LJURR6) |  |  |
| \$YFF73E | LEFT-JUSTIFIED UNSIGNED ADC RESULT REGISTER 7 (LJURR7) |  |  |

1. $Y=M 111$, where $M$ is the logic state of the module mapping (MM) bit in the SCIMCR.

### 5.5 ADC Registers

The following section provides a summary of ADC registers and their contents.

| ADCM | R - | DC | dul | on | guratio |  |  |  |  |  |  |  |  |  | 700 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| STOP |  |  |  |  | NOT US |  |  | SUPV |  |  |  | US |  |  |  |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 | 0 | 0 |  |  |  |  |  | 0 |  |  |  |  |  |  |  |

The ADCMCR is used to initialize the ADC.
STOP - STOP Mode
$0=$ Normal operation
1 = Low-power operation
STOP places the ADC in low-power state by disabling the ADC clock and powering down the analog circuitry. Setting STOP aborts any conversion in progress. STOP is set to logic level one at reset, and may be cleared to logic level zero by the CPU.

Clearing STOP enables normal ADC operation. However, because analog circuitry bias current has been turned off, there is a period of recovery before output stabilization.

FRZ[1:0] - FREEZE Assertion Response
The FRZ field is used to determine ADC response to assertion of the IMB FREEZE signal. Table 39 shows possible responses.

Table 39 FREEZE Assertion Response

| FRZ[1:0] | Response |
| :---: | :--- |
| 00 | Ignore FREEZE |
| 01 | Reserved |
| 10 | Finish conversion, then freeze |
| 11 | Freeze immediately |

SUPV — Supervisor/Unrestricted Data Space
This bit has no effect because the CPU16 always operates in the supervisor mode.
ADTEST - ADC Test Register
\$YFF702
ADTEST is used during factory test of the ADC.


RESET:

$$
0 \quad 0 \quad \text { REFLECTS STATE OF THE INPUT PINS }
$$

Port ADA is an input port that shares pins with the A/D converter inputs.
PADA[7:6] — Port ADA Data Pins
PADA[7:6] digital inputs to the ADC module are internally connected to $\mathrm{V}_{\text {SSA }}$. The corresponding bits in PORTADA will read zero at all times.

PADA[5:0] — Port ADA Data Pins
A read of PADA[5:0] returns the logic level of the port ADA pins. If an input is not at an appropriate logic level (i.e. outside the defined levels), the read is indeterminate. Use of a port ADA pin for digital input does not preclude use as an analog input.

ADCTLO - A/D Control Register 0 \$YFF70A

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  | NOT USED |  | RES10 | STS[1:0] |  |  |  |  |  |  |  |  |  |  |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

ADCTLO is used to select ADC clock source and to set up prescaling. Writes to it have immediate effect.

RES10-10-Bit Resolution
$0=8$-bit resolution
$1=10$-bit resolution
Conversion results are appropriately aligned in result registers to reflect conversion status.
STS[1:0] — Sample Time Select
Total conversion time depends on initial sample time, transfer time, final sample time, and resolution time. Initial sample time is fixed at two clocks. Transfer time is fixed at two clocks. Resolution time is fixed at 10 ADC clock cycles for an 8-bit conversion and 12 ADC clock cycles for a 10-bit conversion. Final sample time depends on the STS[1:0] field. Refer to Table 40.

Table 40 Sample Time Select Field

| STS[1:0] | Sample Time |
| :---: | :---: |
| 00 | $2 \mathrm{~A} / \mathrm{D}$ Clock Periods |
| 01 | $4 \mathrm{~A} / \mathrm{D}$ Clock Periods |
| 10 | $8 \mathrm{~A} / \mathrm{D}$ Clock Periods |
| 11 | $16 \mathrm{~A} / \mathrm{D}$ Clock Periods |

PRS[4:0] - Prescaler Rate Selection Field
The ADC clock is generated from the system clock using a modulo counter and a divide-by-two circuit. The binary value of this field is the counter modulus. System clock is divided by the PRS[4:0] value plus one, then sent to the divide-by-two circuit. Refer to Table 41.

Table 41 Prescaler Rate Selection Field

| PRS[4:0] | Divisor Value |
| :---: | :---: |
| 00000 | 4 |
| 00001 | 4 |
| 00010 | 6 |
| $\ldots$ | $\ldots$ |
| 11101 | 60 |
| 11110 | 62 |
| 11111 | 64 |

ADCTL1 - A/D Control Register 1
\$YFF70C


ADCTL1 is used to initiate an A/D conversion and to select conversion modes and a conversion channel. It can be written or read at any time. A write to ADCTL1 initiates a conversion sequence. If a conversion sequence is already in progress, a write to ADCTL1 aborts it and resets the SCF and CCF flags in the ADC status register.

SCAN - Scan Mode Selection Bit
$0=$ Single conversion sequence
1 = Continuous conversion
Length of conversion sequence(s) is determined by S8CM.
MULT - Multichannel Conversion Bit
$0=$ Conversion sequence(s) run on single channel (channel selected via [CD:CA])
1 = Sequential conversion of a block of four or eight channels (block selected via [CD:CA])
Length of conversion sequence(s) is determined by S8CM.
S8CM - Select Eight-Conversion Sequence Mode
0 = Four-conversion sequence
1 = Eight-conversion sequence
This bit determines the number of conversions in a conversion sequence.
[CD:CA] — Channel Selection Field
The bits in this field are used to select an input or block of inputs for A/D conversion.
Table 42 summarizes the operation of S8CM and [CD:CA] when MULT is cleared (single channel mode). Number of conversions per channel is determined by SCAN.

Table 42 Single-Channel Conversions

| S8CM | CD | CC | CB | CA | Input | Result Register |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | AN0 | RSLT[0:3] |
| 0 | 0 | 0 | 0 | 1 | AN1 | RSLT[0:3] |
| 0 | 0 | 0 | 1 | 0 | AN2 | RSLT[0:3] |
| 0 | 0 | 0 | 1 | 1 | AN3 | RSLT[0:3] |
| 0 | 0 | 1 | 0 | 0 | AN4 | RSLT[0:3] |
| 0 | 0 | 1 | 0 | 1 | AN5 | RSLT[0:3] |
| 0 | 1 | 1 | 1 | 0 | AN6 ${ }^{1}$ | RSLT[0:3] ${ }^{1}$ |
| 0 | 0 | 1 | 1 | 1 | AN7 ${ }^{1}$ | RSLT[0:3] ${ }^{1}$ |
| 0 | 1 | 0 | 0 | 0 | Reserved | RSLT[0:3] |
| 0 | 1 | 0 | 0 | 1 | Reserved | RSLT[0:3] |
| 0 | 1 | 0 | 1 | 0 | Reserved | RSLT[0:3] |
| 0 | 1 | 0 | 1 | 1 | Reserved | RSLT[0:3] |
| 0 | 1 | 1 | 0 | 0 | $\mathrm{V}_{\mathrm{RH}}$ | RSLT[0:3] |
| 0 | 1 | 1 | 0 | 1 | $\mathrm{V}_{\mathrm{RL}}$ | RSLT[0:3] |
| 0 | 1 | 1 | 1 | 0 | $\left(\mathrm{V}_{\mathrm{RH}}-\mathrm{V}_{\mathrm{RL}}\right) / 2$ | RSLT[0:3] |
| 0 | 1 | 1 | 1 | 1 | Test/Reserved | RSLT[0:3] |
| 1 | 0 | 0 | 0 | 0 | AN0 | RSLT[0:7] |
| 1 | 0 | 0 | 0 | 1 | AN1 | RSLT[0:7] |
| 1 | 0 | 0 | 1 | 0 | AN2 | RSLT[0:7] |
| 1 | 0 | 0 | 1 | 1 | AN3 | RSLT[0:7] |
| 1 | 0 | 1 | 0 | 0 | AN4 | RSLT[0:7] |
| 1 | 0 | 1 | 0 | 1 | AN5 | RSLT[0:7] |
| 1 | 0 | 1 | 1 | 0 | AN6 ${ }^{1}$ | RSLT[0:7] ${ }^{1}$ |
| 1 | 0 | 1 | 1 | 1 | AN7 ${ }^{1}$ | RSLT[0:7] ${ }^{1}$ |
| 1 | 1 | 0 | 0 | 0 | Reserved | RSLT[0:7] |
| 1 | 1 | 0 | 0 | 1 | Reserved | RSLT[0:7] |
| 1 | 1 | 0 | 1 | 0 | Reserved | RSLT[0:7] |
| 1 | 1 | 0 | 1 | 1 | Reserved | RSLT[0:7] |
| 1 | 1 | 1 | 0 | 0 | $\mathrm{V}_{\mathrm{RH}}$ | RSLT[0:7] |
| 1 | 1 | 1 | 0 | 1 | $\mathrm{V}_{\mathrm{RL}}$ | RSLT[0:7] |
| 1 | 1 | 1 | 1 | 0 | $\left(\mathrm{V}_{\mathrm{RH}}-\mathrm{V}_{\mathrm{RL}}\right) / 2$ | RSLT[0:7] |
| 1 | 1 | 1 | 1 | 1 | Test/Reserved | RSLT[0:7] |

1. AN6 and AN7 are internally connected to $\mathrm{V}_{\mathrm{RL}}$. Corresponding result register values always read $\$ 0000$.

Table 43 summarizes the operation of S8CM and [CD:CA] when MULT is set (multichannel mode). Number of conversions per channel is determined by SCAN. Channel numbers are given in order of conversion.

Table 43 Multiple-Channel Conversions

| S8CM | CD | CC | CB | CA | Input | Result Register |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | X | X | ANO | RSLTO |
|  |  |  |  |  | AN1 | RSLT1 |
|  |  |  |  |  | AN2 | RSLT2 |
|  |  |  |  |  | AN3 | RSLT3 |
| 0 | 0 | 1 | X | X | AN4 | RSLT0 |
|  |  |  |  |  | AN5 | RSLT1 |
|  |  |  |  |  | AN6 ${ }^{1}$ | RSLT2 ${ }^{1}$ |
|  |  |  |  |  | AN7 ${ }^{1}$ | RSLT3 ${ }^{1}$ |
| 0 | 1 | 0 | X | X | Reserved | RSLTO |
|  |  |  |  |  | Reserved | RSLT1 |
|  |  |  |  |  | Reserved | RSLT2 |
|  |  |  |  |  | Reserved | RSLT3 |
| 0 | 1 | 1 | X | X | $\mathrm{V}_{\text {RH }}$ | RSLTO |
|  |  |  |  |  | $\mathrm{V}_{\mathrm{RL}}$ | RSLT1 |
|  |  |  |  |  | $\left(\mathrm{V}_{\mathrm{RH}}-\mathrm{V}_{\mathrm{RL}}\right) / 2$ | RSLT2 |
|  |  |  |  |  | Test/Reserved | RSLT3 |
| 1 | 0 | X | X | X | ANO | RSLT0 |
|  |  |  |  |  | AN1 | RSLT1 |
|  |  |  |  |  | AN2 | RSLT2 |
|  |  |  |  |  | AN3 | RSLT3 |
|  |  |  |  |  | AN4 | RSLT4 |
|  |  |  |  |  | AN5 | RSLT5 |
|  |  |  |  |  | AN6 ${ }^{1}$ | RSLT6 ${ }^{1}$ |
|  |  |  |  |  | AN7 ${ }^{1}$ | RSLT7 ${ }^{1}$ |
| 1 | 1 | X | X | X | Reserved | RSLT0 |
|  |  |  |  |  | Reserved | RSLT1 |
|  |  |  |  |  | Reserved | RSLT2 |
|  |  |  |  |  | Reserved | RSLT3 |
|  |  |  |  |  | $\mathrm{V}_{\text {RH }}$ | RSLT4 |
|  |  |  |  |  | $\mathrm{V}_{\mathrm{RL}}$ | RSLT5 |
|  |  |  |  |  | $\left(\mathrm{V}_{\mathrm{RH}}-\mathrm{V}_{\mathrm{RL}}\right) / 2$ | RSLT6 |
|  |  |  |  |  | Test/Reserved | RSLT7 |

1. AN6 and AN7 are internally connected to $\mathrm{V}_{\mathrm{RL}}$. Corresponding result register values always read $\$ 0000$.

| ADST | - | DC S | us | gist |  |  |  |  |  |  |  |  |  |  | 70E |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| SCF |  |  |  |  |  | CCTR[2:0] |  |  |  |  |  |  |  |  |  |
| RESET |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 |  |  |  |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

ADSTAT contains information related to the status of a conversion sequence.
SCF - Sequence Complete Flag
$0=$ Sequence not complete
1 = Sequence complete
SCF is set at the end of the conversion sequence when SCAN is cleared, and at the end of the first conversion sequence when SCAN is set. SCF is cleared when ADCTL1 is written and a new conversion sequence begins.

CCTR[2:0] - Conversion Counter Field
This field reflects the contents of the conversion counter pointer in either four or eight count conversion sequence. The value corresponds to the number of the next result register to be written, and thus indicates which channel is being converted.

CCF[7:0] - Conversion Complete Field
Each bit in this field corresponds to an A/D result register (CCF7 to RSLT7, etc.). A bit is set when conversion for the corresponding channel is complete, and remains set until the result register is read.

## RSLT[0:7] — A/D Result Registers

## \$YFF710-\$YFF73E

The result registers are used to store data after conversion is complete. Each register can be read from three different addresses in the register block. Data format depends on the address from which it is read.

RJURR[0:7] — Unsigned Right-Justified Format
\$YFF710-\$YFF71F
Conversion result is unsigned right-justified data. Bits [9:0] are used for 10-bit resolution. For 8-bit conversions, bits [7:0] contain data and bits [9:8] are zero. Bits [15:10] always return zero when read.

LJSRR[0:7] — Signed Left-Justified Format
\$YFF720-\$YFF72F
Conversion result is signed left-justified data. Bits [15:6] are used for 10-bit resolution. For 8-bit conversions, bits [15:8] contain data and bits [7:6] are zero. Although the ADC is unipolar, it is assumed that the zero point is halfway between low and high reference when this format is used - for positive input, bit $15=0$, for negative input, bit $15=1$. Bits [ $5: 0$ ] always return zero when read.

LJURR[0:7] — Unsigned Left-Justified Format
\$YFF730-\$YFF73F
Conversion result is unsigned left-justified data. Bits [15:6] are used for 10-bit resolution. For 8-bit conversions, bits [15:8] contain data and bits [7:6] are zero. Bits [5:0] always return zero when read.

## 6 General-Purpose Timer Module

The GPT is a simple, yet flexible 11-channel timer used in systems where a moderate degree of external visibility and control is required. The GPT consists of a capture/compare unit, a pulse accumulator, and two pulse-width modulators. A bus interface unit connects the GPT to the intermodule bus.

Figure 14 shows a block diagram of the GPT.


GPT Block
Figure 14 GPT Block Diagram

### 6.1 Overview

The capture/compare unit features three input capture channels, four output compare channels and one selectable input capture/output compare channel. These channels share a 16 -bit free-running counter (TCNT), which derives its clock from a nine-stage prescaler or from the external clock input signal (PCLK).

Pulse accumulator channel logic includes an 8-bit counter; the pulse accumulator can operate in either event counting mode or gated time accumulation mode.

Pulse-width modulator outputs are periodic waveforms whose duty cycles can be independently selected and modified by user software. The PWM circuits share a 16 -bit free-running counter that can be clocked by the same nine-stage prescaler used by the capture/compare unit or by the PCLK input.

All GPT pins can also be used for general-purpose input/output. The input capture and output compare pins form a bidirectional 8-bit parallel port (PORTGP). PWM pins are outputs only. PAI and PCLK pins are inputs only.

GPT input capture/output compare pins are bidirectional and can be used to form an 8-bit parallel port. The pulse-width modulator outputs can be used as general-purpose outputs. The PAI and PCLK inputs can be used as general-purpose inputs.

### 6.2 GPT Address Map

Table 44 shows the GPT address map.

Table 44 GPT Address Map

| Address | 15 8 | 70 |
| :---: | :---: | :---: |
| \$YFF900 ${ }^{1}$ | GPT MODULE CONFIGURATION REGISTER (GPTMCR) |  |
| \$YFF902 | GPT MODULE TEST REGISTER (GPTMTR) |  |
| \$YFF904 | INTERRUPT CONFIGURATION REGISTER (ICR) |  |
| \$YFF906 | PGP DATA DIRECTION (DDRGP) | PGP DATA (PORTGP) |
| \$YFF908 | OC1 ACTION MASK (OC1M) | OC1 ACTION DATA (OC1D) |
| \$YFF90A | TIMER COUNTER (TCNT) |  |
| \$YFF90C | PULSE ACCUMULATOR CONTROL <br> (PACTL) | PULSE ACCUMULATOR COUNTER (PACNT) |
| \$YFF90E | TIMER INPUT CAPTURE 1 (TIC1) |  |
| \$YFF910 | TIMER INPUT CAPTURE 2 (TIC2) |  |
| \$YFF912 | TIMER INPUT CAPTURE 3 (TIC3) |  |
| \$YFF914 | TIMER OUTPUT COMPARE 1 (TOC1) |  |
| \$YFF916 | TIMER OUTPUT CAPTURE 2 (TOC2) |  |
| \$YFF918 | TIMER OUTPUT CAPTURE 3 (TOC3) |  |
| \$YFF91A | TIMER OUTPUT CAPTURE 4 (TOC4) |  |
| \$YFF91C | TIMER INPUT CAPTURE 4/OUTPUT COMPARE 5 (TI4/O5) |  |
| \$YFF91E | TIMER CONTROL 1 (TCTL1) | TIMER CONTROL 2 (TCTL2) |
| \$YFF920 | TIMER MASK 1 (TMSK1) | TIMER MASK 2 (TMSK2) |
| \$YFF922 | TIMER FLAG 1 (TFLG1) | TIMER FLAG 2 (TFLG2) |
| \$YFF924 | FORCE COMPARE (CFORC) | PWM CONTROL C (PWMC) |
| \$YFF926 | PWMA DUTY CYCLE (PWMA) | PWMB DUTY CYCLE (PWMB) |
| \$YFF928 | PWM COUNT REGISTER (PWMCNT) |  |
| \$YFF92A | PWMA BUFFER (PWMBUFA) | PWMB BUFFER (PWMBUFB) |
| \$YFF92C | GPT PRESCALER (PRESCL) |  |
| \$YFF92E\$YFF93F | RESERVED |  |

1. $Y=M 111$, where $M$ is the logic state of the module mapping (MM) bit in the SCIMCR.

### 6.3 Capture/Compare Unit

The capture/compare unit features three input capture channels, four output compare channels, and one input capture/output compare channel (function selected by control register). Refer to Figure 15.

These channels share a 16 -bit free-running counter (TCNT), which derives its clock from seven stages of a 9-stage prescaler. Refer to Figure 16.

This section also contains one pulse accumulator channel. The pulse accumulator logic includes its own 8 -bit counter and can operate in either event counting mode or gated time accumulation mode. Refer to Figure 17.


Figure 15 GPT Capture/Compare Block Diagram


GPT PRE BLOCK
Figure 16 Prescaler Block Diagram


16/32 PULSE ACC BLOCK

Figure 17 Pulse Accumulator Block Diagram

### 6.4 Pulse-Width Modulator

The pulse-width modulation submodule has two output pins. The outputs are periodic waveforms controlled by a single frequency whose duty cycles can be independently selected and modified by user software. Each PWM can be independently programmed to run in fast or slow mode. The PWM unit has its own 16 -bit free-running counter, which is clocked by an output of the nine-stage prescaler (the same prescaler used by the capture/compare unit) or by the clock input pin, PCLK.

Figure 18 displays a block diagram of the PWM unit.


16/32 PWM BLOCK
Figure 18 PWM Unit Block Diagram

### 6.5 GPT Registers

The following section provides a summary of GPT registers and their contents.

GPTMCR - GPT Module Configuration Register
\$YFF900

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| STOP | FRZ1 | FRZO | STOPP | INCP | 0 | 0 | 0 | SUPV | 0 | 0 | 0 |  | IARB[3:0] |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

The GPTMCR contains parameters for configuring the GPT.
STOP - Stop Clocks
$0=$ Internal clocks not shut down
1 = Internal clocks shut down
FRZ1 - Not Implemented
FRZO - FREEZE Assertion Response
$0=$ Ignore IMB FREEZE Signal
$1=$ FREEZE the current state of the GPT
STOPP - Stop Prescaler
$0=$ Normal operation
1 = Stop prescaler and pulse accumulator from incrementing. Ignore changes to input pins.
INCP — Increment Prescaler
$0=$ Has no meaning
$1=$ If STOPP is asserted, increment prescaler once and clock input synchronizers once.

## SUPV - Supervisor/Unrestricted Data Space

This bit has no effect because the CPU16 always operates in the supervisor mode.
IARB[3:0] - Interrupt Arbitration Identification
The value in this field is used to arbitrate between simultaneous interrupt service requests of the same priority. Each module that can generate interrupts has an IARB field. In order to implement an arbitration scheme, each IARB field must be set to a different non-zero value. If an interrupt request from a module that has an IARB field value of $\$ 0$ is recognized, the CPU16 processes a spurious interrupt exception. The reset value of all IARB fields other than that of the SCIM is $\$ 0$ (no priority), to preclude interrupt processing during reset.

## GPTMTR — GPT Module Test Register

\$YFF902
This address is reserved for GPT factory test.

ICR — GPT Interrupt Configuration Register

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | IPA[3:0] |  |  | 0 |  | IPL[2:0] |  |  | IVBA[3:0] |  |  | 0 | 0 | 0 | 0 |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

IPA[3:0] - Interrupt Priority Adjust
This field specifies which GPT interrupt source is given highest internal priority. Refer to Table 45.

Table 45 GPT Interrupt Sources

| Name | Source Number | Source | Vector Number |
| :---: | :---: | :---: | :---: |
| - | 0000 | Adjusted Channel | IVBA : 0000 |
| IC1 | 0001 | Input Capture 1 | IVBA :0001 |
| IC2 | 0010 | Input Capture 2 | IVBA $: 0010$ |
| IC3 | 0011 | Input Capture 3 | IVBA :0011 |
| OC1 | 0100 | Output Compare 1 | IVBA :0100 |
| OC2 | 0101 | Output Compare 2 | IVBA :0101 |
| OC3 | 0110 | Output Compare 3 | IVBA $: 0110$ |
| OC4 | 0111 | Output Compare 4 | IVBA $: 0111$ |
| IC4/OC5 | 1000 | Input Capture 4/Output Compare 5 | IVBA : 1000 |
| TO | 1001 | Timer Overflow | IVBA $: 1001$ |
| PAOV | 1010 | Pulse Accumulator Overflow | IVBA $: 1010$ |
| PAI | 1011 | Pulse Accumulator Input | IVBA $: 1011$ |

IPL[2:0] — Interrupt Priority Level
This field specifies the priority level of interrupts generated by the GPT.
IVBA[3:0] — Interrupt Vector Base Address
Most significant nibble of interrupt vector numbers generated by the GPT. Refer to Table 45.
DDRGP/PORTGP — Port GP Data Direction Register/Port GP Data Register \$YFF906

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DDRGP |  |  |  |  |  |  |  | PORTGP |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

When GPT pins are used as an 8-bit port, DDRGP determines whether pins are input or output and PORTGP holds the 8 -bit data.

DDRGP[7:0] — Port GP Data Direction Register
$0=$ Input only
1 = Output
OC1M/OC1D — OC1 Action Mask Register/OC1 Action Data Register \$YFF908

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OC1M[5:1] |  |  |  |  | 0 | 0 | 0 | OC1D[5:1] |  |  |  |  | 0 | 0 | 0 |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

All OC outputs can be controlled by the action of OC1. OC1M contains a mask that determines which pins are affected. OC1D determines what the outputs are.

OC1M[5:1] — OC1 Mask Field
$0=$ Corresponding output compare pin is not affected by OC1 compare.
$1=$ Corresponding output compare pin is affected by OC1 compare.
OC1M[5:1] correspond to OC[5:1].
OC1D[5:1] - OC1 Data Field
$0=$ If OC1 mask bit is set, clear the corresponding output compare pin on OC1 match.
$1=$ If OC1 mask bit is set, set the corresponding output compare pin on OC1 match.
OC1D[5:1] correspond to OC[5:1].

TCNT is the 16 -bit free-running counter associated with the input capture, output compare, and pulse accumulator functions of the GPT module.

PACTL/PACNT - Pulse Accumulator Control Register/Counter
\$YFF90C


PACTL enables the pulse accumulator and selects either event counting or gated mode. In event counting mode, PACNT is incremented each time an event occurs. In gated mode, it is incremented by an internal clock.

PAIS — PAI Pin State (Read Only)
PAEN - Pulse Accumulator Enable
$0=$ Pulse accumulator disabled
1 = Pulse accumulator enabled
PAMOD - Pulse Accumulator Mode
$0=$ External event counting
1 = Gated time accumulation
PEDGE - Pulse Accumulator Edge Control
The effects of PAMOD and PEDGE are shown in Table 46.
Table 46 PAMOD/PEDGE Effects

| PAMOD | PEDGE | Effect |
| :---: | :---: | :---: |
| 0 | 0 | PAI falling edge increments counter |
| 0 | 1 | PAI rising edge increments counter |
| 1 | 0 | Zero on PAI inhibits counting |
| 1 | 1 | One on PAI inhibits counting |

PCLKS - PCLK Pin State (Read Only)
14/O5 - Input Capture 4/Output Compare 5
$0=$ Output compare 5 enabled
1 = Input capture 4 enabled
PACLK[1:0] — Pulse Accumulator Clock Select (Gated Mode)
Table 47 shows the PACLK[1:0] bit field effects.

Table 47 PACLK[1:0] Bit Field

| PACLK[1:0] | Pulse Accumulator Clock Selected |
| :---: | :---: |
| 00 | System clock divided by 512 |
| 01 | Same clock used to increment TCNT |
| 10 | TOF flag from TCNT |
| 11 | External clock, PCLK |

PACNT - Pulse Accumulator Counter
Eight-bit read/write counter used for external event counting or gated time accumulation.

TIC[1:3] - Input Capture Registers 1-3
\$YFF90E, \$YFF910, \$YFF912
The input capture registers are 16 -bit read-only registers which are used to latch the value of TCNT when a specified transition is detected on the corresponding input capture pin. They are reset to \$FFFF.

TOC[1:4] — Output Compare Registers 1-4
\$YFF914, \$YFF916, \$YFF918, \$YFF91A
The output compare registers are 16-bit read/write registers which can be used as output waveform controls or as elapsed time indicators. For output compare functions, they are written to a desired match value and compared against TCNT to control specified pin actions. They are reset to \$FFFF.

T14/05 - Input Capture 4/Output Compare 5 Register
\$YFF91C
This register serves either as input capture register 4 or output compare register 5, depending on the state of 14/O5 in PACTL.

TCTL1/TCTL2 - Timer Control Registers 1-2
\$YFF91E

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OM5 | OL5 | OM4 | OL4 | OM3 | OL3 | OM2 | OL2 | EDG4B | EDG4A | EDG3B | EDG3A | EDG2B | EDG2A | EDG1B | EDG1A |

RESET:
$\begin{array}{llllllllllllllll}0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0\end{array}$
TCTL1 determines output compare mode and output logic level. TCTL2 determines the type of input capture to be performed.

OM/OL[5:2] — Output Compare Mode Bits and Output Compare Level Bits
Each pair of bits specifies an action to be taken when output comparison is successful. Refer to Table 48.

Table 48 OM/OL[5:2] Bit Field Effects

| OM/OL[5:2] | Action Taken |
| :---: | :---: |
| 00 | Timer disconnected from output logic |
| 01 | Toggle OCx output line |
| 10 | Clear OCx output line to 0 |
| 11 | Set OCx output line to 1 |

EDG[4:1]B/A - Input Capture Edge Control Bits
Each pair of bits configures input sensing logic for the corresponding input capture. Refer to Table 49.

Table 49 EDG[4:1]B/A Bit Field Effects

| EDG[4:1]B/A | Configuration |
| :---: | :---: |
| 00 | Capture disabled |
| 01 | Capture on rising edge only |
| 10 | Capture on falling edge only |
| 11 | Capture on any (rising or falling) edge |

TMSK1/TMSK2 - Timer Interrupt Mask Registers 1-2
\$YFF920


TMSK1 enables OC and IC interrupts. TMSK2 controls pulse accumulator interrupts and TCNT functions.

14/O5I — Input Capture 4/Output Compare 5 Interrupt Enable
0 = IC4/OC5 interrupt disabled.
1 = IC4/OC5 interrupt requested when I4/O5F flag in TFLG1 is set.
OCI[4:1] — Output Compare Interrupt Enable
$0=O C$ interrupt disabled
$1=O C$ interrupt requested when OC flag set
OCI[4:1] correspond to OC[4:1].
ICI[3:1] — Input Capture Interrupt Enable
$0=I C$ interrupt disabled
$1=I C$ interrupt requested when IC flag set
ICI[3:1] correspond to IC[3:1].
TOI - Timer Overflow Interrupt Enable
0 = Timer overflow interrupt disabled
1 = Interrupt requested when TOF flag is set
PAOVI — Pulse Accumulator Overflow Interrupt Enable
$0=$ Pulse accumulator overflow interrupt disabled
$1=$ Interrupt requested when PAOVF flag is set
PAII - Pulse Accumulator Input Interrupt Enable
$0=$ Pulse accumulator interrupt disabled
$1=$ Interrupt requested when PAIF flag is set
CPROUT - Compare/Capture Unit Clock Output Enable
$0=$ Normal operation for OC1 pin
$1=$ TCNT clock driven out OC1 pin
CPR[2:0] - Timer Prescaler/PCLK Select Field
This field selects one of seven prescaler taps or PCLK to be TCNT input. Refer to Table 50.

Table 50 CPR[2:0] Bit Field Effects

| CPR[2:0] | System Clock Divide-By Factor |
| :---: | :---: |
| 000 | 4 |
| 001 | 8 |
| 010 | 16 |
| 011 | 32 |
| 100 | 64 |
| 101 | 128 |
| 110 | 256 |
| 111 | PCLK |

TFLG1/TFLG2 - Timer Interrupt Flag Registers 1-2

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 14/05F |  | OCF[4:1] |  |  |  | ICF[3:1] |  | TOF | 0 | PAOVF | PAIF | 0 | 0 | 0 | 0 |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

These registers show condition flags that correspond to various GPT events. If the corresponding interrupt enable bit in TMSK1/TMSK2 is set, an interrupt occurs.

14/O5F — Input Capture 4/Output Compare 5 Flag
When I4/O5 in PACTL is zero, this flag is set each time TCNT matches the value in TOC5. When 14/O5 in PACTL is one, the flag is set each time a selected edge is detected at the I4/O5 pin.

OCF[4:1] — Output Compare Flags
An output compare flag is set each time TCNT matches the corresponding TOC register. OCF[4:1] correspond to OC[4:1].

## ICF[3:1] — Input Capture Flags

A flag is set each time a selected edge is detected at the corresponding input capture pin. ICF[3:1] correspond to IC[3:1].

## TOF - Timer Overflow Flag

This flag is set each time TCNT advances from a value of \$FFFF to $\$ 0000$.

## PAOVF - Pulse Accumulator Overflow Flag

This flag is set each time the pulse accumulator counter advances from a value of $\$ F F$ to $\$ 00$.
PAIF - Pulse Accumulator Flag
In event counting mode, this flag is set when an active edge is detected on the PAI pin. In gated time accumulation mode, PAIF is set at the end of the timed period.

CFORC/PWMC - Compare Force Register/PWM Control Register \$YFF924


Setting a bit in CFORC causes a specific output on OC. PWMC controls operation of the GPT PWM submodule.

FOC[5:1] — Force Output Compare
$0=$ Causes no action on corresponding OC pin.
$1=$ Causes pin action programmed for corresponding OC pin, but the OC flag is not set.
FOC[5:1] correspond to OC[5:1].
FPWMA/B - Force PWM Value
$0=P W M$ pin $A / B$ is used for PWM functions; normal operation.
$1=P W M$ pin $A / B$ is used for discrete output. The value of the $F 1 A / B$ bit will be driven out on the PWMA/B pin. This is true for PWMA regardless of the state of the PPROUT bit.

PPROUT - PWM Clock Output Enable
$0=$ Normal PWM operation on PWMA
$1=$ Clock selected by PPR[2:0] is driven out PWMA pin.

PPR[2:0] — PWM Prescaler/PCLK Select
This field selects one of seven prescaler taps, or PCLK, to be PWMCNT input. Refer to Table 51.
Table 51 PWM Prescaler/PCLK Select Taps

| PPR[2:0] | System Clock <br> Divide-By Factor |
| :---: | :---: |
| 000 | 2 |
| 001 | 4 |
| 010 | 8 |
| 011 | 16 |
| 100 | 32 |
| 101 | 64 |
| 110 | 128 |
| 111 | PCLK |

SFA/B — PWMA/B Slow/Fast Select
$0=P W M A / B$ period is 256 PWMCNT increments long.
$1=$ PWMA/B period is 32768 PWMCNT increments long.
Table 52 shows the effects of settings on PWM frequency for a $16.78-\mathrm{MHz}$ system clock.
Table 52 Effects of SFA/B Settings on PWM Frequency

| PPR[2:0] | Prescaler Tap | SFA/B = 0 | SFA/B = 1 |
| :---: | :---: | :---: | :---: |
| 000 | Div $2=8.39 \mathrm{MHz}$ | 32.8 kHz | 256 Hz |
| 001 | Div $4=4.19 \mathrm{MHz}$ | 16.4 kHz | 128 Hz |
| 010 | Div $8=2.10 \mathrm{MHz}$ | 8.19 kHz | 64.0 Hz |
| 011 | Div $16=1.05 \mathrm{MHz}$ | 4.09 kHz | 32.0 Hz |
| 100 | Div $32=524 \mathrm{kHz}$ | 2.05 kHz | 16.0 Hz |
| 101 | Div $64=262 \mathrm{kHz}$ | 1.02 kHz | 8.0 Hz |
| 110 | Div $128=131 \mathrm{kHz}$ | 512 Hz | 4.0 Hz |
| 111 | PCLK | PCLK/256 | PCLK/32768 |

F1A/B - Force Logic Level One on PWMA/B
$0=$ Force logic level zero output on PWMA/B pin
1 = Force logic level one output on PWMA/B pin
PWMA/PWMB - PWM Duty Cycle Registers A/B
\$YFF926, \$YFF927
These registers are associated with the pulse-width value of the PWM output on the corresponding PWM pin. A value of $\$ 00$ loaded into one of these registers results in a continuously low output on the corresponding pin. A value of $\$ 80$ results in a $50 \%$ duty cycle output. Maximum value (\$FF) selects an output that is high for 255/256 of the period.

PWMCNT — PWM Count Register
\$YFF928
PWMCNT is the 16-bit free-running counter associated with the PWM functions of the GPT module.
PWMBUFA/B — PWM Buffer Registers A/B
\$YFF92A, \$YFF92B
These read-only registers contain values associated with the duty cycles of the corresponding PWM. Reset state for both registers is $\$ 00$.

PRESCL — GPT Prescaler
The 9-bit prescaler value can be read from bits [8:0] at this address. Bits [15:9] always read as zeros. Reset state is $\$ 0000$.

## 7 Queued Serial Module

The QSM contains two serial interfaces, the queued serial peripheral interface (QSPI) and the serial communication interface (SCI). Figure 19 shows the QSM block diagram.


QSM BLOCK

Figure 19 QSM Block Diagram

### 7.1 Overview

The QSPI provides peripheral expansion or interprocessor communication through a full-duplex, synchronous, three-line bus: data in, data out, and a serial clock. Four programmable peripheral chip-select pins provide addressability for up to 16 peripheral devices. A self-contained RAM queue allows up to 16 serial transfers of 8 to 16 bits each, or transmission of a 256 -bit data stream without CPU intervention. A special wraparound mode supports continuous sampling of a serial peripheral, with automatic QSPI RAM updating, which makes the interface to A/D converters more efficient.

The SCI provides a standard nonreturn to zero (NRZ) mark/space format. It operates in either fullor half-duplex mode. There are separate transmitter and receiver enable bits and dual data buffers. A modulus-type baud rate generator provides rates from 64 to 524 kbaud with a 16.78 MHz system clock. Word length of either 8 or 9 bits is software selectable. Optional parity generation and detection provide either even or odd parity check capability. Advanced error detection circuitry catches glitches of up to $1 / 16$ of a bit time in duration. Wake-up functions allow the CPU to run uninterrupted until meaningful data is available.

Table 53 shows the address map of the QSM.

Table 53 QSM Address Map

| Address | 15 8 | 7 0 |
| :---: | :---: | :---: |
| \$YFFC00 ${ }^{1}$ | QSM MODULE CONFIGURATION (QSMCR) |  |
| \$YFFC02 | QSM TEST (QTEST) |  |
| \$YFFC04 | QSM INTERRUPT LEVEL (QILR) | QSM INTERRUPT VECTOR (QIVR) |
| \$YFFC06 | RESERVED |  |
| \$YFFC08 | SCI CONTROL 0 REGISTER (SCCR0) |  |
| \$YFFC0A | SCI CONTROL 1 REGISTER (SCCR1) |  |
| \$YFFC0C | SCI STATUS REGISTER (SCSR) |  |
| \$YFFC0E | SCI DATA REGISTER (SCDR) |  |
| \$YFFC10 | RESERVED |  |
| \$YFFC12 | RESERVED |  |
| \$YFFC14 | NOT USED | PQS DATA (PORTQS) |
| \$YFFC16 | PQS PIN ASSIGNMENT (PQSPAR) | PQS DATA DIRECTION (DDRQS) |
| \$YFFC18 | SPI CONTROL 0 REGISTER (SPCR0) |  |
| \$YFFC1A | SPI CONTROL 1 REGISTER (SPCR1) |  |
| \$YFFC1C | SPI CONTROL 2 REGISTER (SPCR2) |  |
| \$YFFC1E | SPI CONTROL 3 REGISTER (SPCR3) | SPI STATUS REGISTER (SPSR) |
| $\begin{aligned} & \text { \$YFFC20- } \\ & \text { \$YFFCFF } \end{aligned}$ | RESERVED |  |
| $\begin{aligned} & \text { \$YFFD00- } \\ & \text { \$YFFD1F } \end{aligned}$ | RECEIVE RAM (RR[0:F]) |  |
| $\begin{aligned} & \text { \$YFFD20- } \\ & \text { \$YFFD3F } \end{aligned}$ | TRANSMIT RAM (TR[0:F]) |  |
| \$YFFD40\$YFFD4F | COMMAND RAM (CR[0:F]) |  |

1. $Y=M 111$, where M is the logic state of the MM bit in the SCIMCR.

### 7.2 Pin Function

Table 54 is a summary of the functions of the QSM pins when they are not configured for generalpurpose I/O. The QSM data direction register (DDRQS) designates each pin except RXD as an input or output.

Table 54 QSM Pin Functions

| Pin | Mode | Pin Function |
| :---: | :---: | :--- |
| MISO | Master | Serial Data Input to QSPI |
|  | Slave | Serial Data Output from QSPI |
| MOSI | Master | Serial Data Output from QSPI |
|  | Slave | Serial Data Input to QSPI |
| SCK | Master | Clock Output from QSPI |
|  | Slave | Clock Input to QSPI |
| PCS0/SS | Master | Input: Assertion Causes Mode Fault <br> Output: Selects Peripherals |
|  | Slave | Input: Selects the QSPI |
|  | Master | Output: Selects Peripherals |
|  | Slave | None |
| TXD | Transmit | Serial Data Output from SCI |
| RXD | Receive | Serial Data Input to SCI |

### 7.3 QSM Registers

QSM registers are divided into four categories: QSM global registers, QSM pin control registers, QSPI submodule registers, and SCI submodule registers. The QSPI and SCI registers are defined in separate sections below. Writes to unimplemented register bits have no meaning or effect, and reads from unimplemented bits always return a logic zero value.

### 7.3.1 Global Registers

The QSM global registers contain system parameters used by both the QSPI and the SCI submodules. These registers contain the bits and fields used to configure the QSM.

| QSMCR — QSM Configuration Register |
| :--- |
| \$YFFC00                <br> 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 <br> STOP FRZ1 FRZO 0 0 0 0 0 SUPV 0 0 0  IARB[3:0]   |
| RESET: |
| 0 |

The QSMCR contains parameters for the QSM/CPU/intermodule bus (IMB) interface.
STOP - Stop Enable
$0=$ Normal QSM clock operation
1 = QSM clock operation stopped
STOP places the QSM in a low-power state by disabling the system clock in most parts of the module. The QSMCR is the only register guaranteed to be readable while STOP is asserted. The QSPI RAM is not readable. However, writes to RAM or any register are guaranteed to be valid while STOP is asserted. STOP can be negated by the CPU and by reset.

The system software must stop each submodule before asserting STOP to avoid complications at restart and to avoid data corruption. The SCI submodule receiver and transmitter should be disabled, and the operation should be verified for completion before asserting STOP. The QSPI submodule should be stopped by asserting the HALT bit in SPCR3 and by asserting STOP after the HALTA flag is set.

## FRZ1 - FREEZE Assertion Response

$0=$ Ignore the FREEZE signal on the IMB
1 = Halt the QSPI (on a transfer boundary)
FRZ1 determines what action is taken by the QSPI when the FREEZE signal of the IMB is asserted. FREEZE is asserted whenever the CPU enters the background mode.

FRZO — Not Implemented
Bits [12:8] — Not Implemented
SUPV - Supervisor/Unrestricted Data Space
This bit has no effect because the CPU16 always operates in the supervisor mode.
IARB[3:0] - Interrupt Arbitration Identification Number
The IARB field is used to arbitrate between simultaneous interrupt requests of the same priority. Each module that can generate interrupt requests must be assigned a unique, non-zero IARB field value.

QTEST is used during factory testing of the QSM.

QILR — QSM Interrupt Levels Register


QILR determines the priority level of interrupts requested by the QSM.
ILQSPI[2:0] — Interrupt Level for QSPI
ILQSPI determines the priority of QSPI interrupts. This field must be given a value between $\$ 0$ (interrupts disabled) to $\$ 7$ (highest priority).

ILSCI[2:0] — Interrupt Level of SCI
ILSCI determines the priority of SCI interrupts. This field must be given a value between $\$ 0$ (interrupts disabled) to $\$ 7$ (highest priority).

If ILQSPI and ILSCI are the same nonzero value, and both submodules simultaneously request interrupt service, QSPI has priority.


At reset, QIVR is initialized to $\$ 0 \mathrm{~F}$, which corresponds to the uninitialized interrupt vector in the exception table. This vector is selected until QIVR is written. A user-defined vector (\$40-\$FF) should be written to QIVR during QSM initialization.

After initialization, QIVR determines which two vectors in the exception vector table are to be used for QSM interrupts. The QSPI and SCI submodules have separate interrupt vectors adjacent to each other. Both submodules use the same interrupt vector with the least significant bit (LSB) determined by the submodule causing the interrupt.

The value of INTV0 used during an interrupt-acknowledge cycle is supplied by the QSM. During an interrupt-acknowledge cycle, INTV[7:1] are driven on DATA[7:1] IMB lines. DATA0 is negated for an SCI interrupt and asserted for a QSPI interrupt. Writes to INTV0 have no meaning or effect. Reads of INTVO return a value of one.

### 7.3.2 Pin Control Registers

The QSM uses nine pins, eight of which form a parallel port (PORTQS) on the MCU. Although these pins are used by the serial subsystems, any pin can alternately be assigned as general-purpose I/ O on a pin-by-pin basis.

Pins used for general-purpose I/O must not be assigned to the QSPI by register PQSPAR. To avoid driving incorrect data, the first byte to be output must be written before DDRQS is configured. DDRQS must then be written to determine the direction of data flow and to output the value contained in register PORTQS. Subsequent data for output is written to PORTQS.

PORTQS — Port QS Data Register
\$YFFC14


PORTQS latches I/O data. Writes drive pins defined as outputs. Reads return data present on the pins. To avoid driving undefined data, first write a byte to PORTQS, then configure DDRQS.

| $\begin{aligned} & \text { PQSF } \\ & \text { DDR } \end{aligned}$ | $\begin{aligned} & A R-F \\ & S-P( \end{aligned}$ | $\begin{aligned} & \text { PORT } \\ & \text { ORT Q } \end{aligned}$ | QS Pin <br> S Data | Assign Direct | men | Registe gister |  |  |  |  |  |  |  |  | $\begin{aligned} & =\mathrm{C} 16 \\ & =\mathrm{C} 17 \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | PQSPA6 | PQSPA5 | PQSPA4 | PQSPA3 | 0 | PQSPA1 | PQSPA0 | DDQS7 | DDQS6 | DDQS5 | DDQS4 | DDQS3 | DDQS2 | DDQS1 | DDQS0 |
|  | ET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

Clearing a bit in PQSPAR assigns the corresponding pin to general-purpose I/O; setting a bit assigns the pin to the QSPI. PQSPAR does not affect operation of the SCI. Table 55 displays PQSPAR pin assignments.

Table 55 PQSPAR Pin Assignments

| PQSPAR Field | PQSPAR Bit | Pin Function |
| :---: | :---: | :---: |
| PQSPA0 | 0 | PQS0 |
|  | 1 | MISO |
| PQSPA1 | 0 | PQS1 |
|  | 1 | MOSI |
| - | - | PQS2 |
|  | - | SCK $^{1}$ |
| PQSPA3 | 0 | PQS3 |
|  | 1 | PCS0/SS |
| PQSPA4 | 0 | PQS4 |
|  | 1 | PCS1 |
| PQSPA5 | 0 | PQS5 |
|  | 1 | PCS2 |
| PQSPA6 | 0 | PQS6 |
|  | 1 | PCS3 |
| - | - | PQS7² |
|  | - | TXD |

1. PQS2 is a digital I/O pin unless the SPI is enabled (SPE in SPCR1 set), in which case it becomes SPI serial clock SCK.
2. PQS7 is a digital I/O pin unless the SCI transmitter is enabled (TE in SCCR1 = 1), in which case it becomes SCI serial output TXD.

DDRQS determines whether pins are inputs or outputs. Clearing a bit makes the corresponding pin an input; setting a bit makes the pin an output. DDRQS affects both QSPI function and I/O function. Table 56 shows the effect of DDRQS on QSM pin functions.

Table 56 Effect of DDRQS on QSM Pin Function

| QSM Pin | Mode | DDRQS Bit | Bit State | Pin Function |
| :---: | :---: | :---: | :---: | :---: |
| MISO | Master | DDQS0 | 0 | Serial Data Input to QSPI |
|  |  |  | 1 | Disables Data Input |
|  | Slave |  | 0 | Disables Data Output |
|  |  |  | 1 | Serial Data Output from QSPI |
| MOSI | Master | DDQS1 | 0 | Disables Data Output |
|  |  |  | 1 | Serial Data Output from QSPI |
|  | Slave |  | 0 | Serial Data Input to QSPI |
|  |  |  | 1 | Disables Data Input |
| SCK ${ }^{1}$ | Master | DDQS2 | 0 | Disables Clock Output |
|  |  |  | 1 | Clock Output from QSPI |
|  | Slave |  | 0 | Clock Input to QSPI |
|  |  |  | 1 | Disables Clock Input |
| PCS0/SS | Master | DDQS3 | 0 | Assertion Causes Mode Fault |
|  |  |  | 1 | Chip-Select Output |
|  | Slave |  | 0 | QSPI Slave Select Input |
|  |  |  | 1 | Disables Select Input |
| PCS[3:1] | Master | DDQS[4:6] | 0 | Disables Chip-Select Output |
|  |  |  | 1 | Chip-Select Output |
|  | Slave |  | 0 | Inactive |
|  |  |  | 1 | Inactive |
| TXD ${ }^{2}$ | Transmit | DDQS7 | X | Serial Data Output from SCI |
| RXD | Receive | None | NA | Serial Data Input to SCI |

1. PQS2 is a digital I/O pin unless the SPI is enabled (SPE in SPCR1 set), in which case it becomes SPI serial clock SCK.
2. PQS7 is a digital I/O pin unless the SCI transmitter is enabled (TE in SCCR1 = 1), in which case it becomes SCl serial output TXD.

DDRQS determines the direction of the TXD pin only when the SCI transmitter is disabled. When the SCI transmitter is enabled, the TXD pin is an output.

### 7.4 QSPI Submodule

The QSPI submodule communicates with external devices through a synchronous serial bus. The QSPI is fully compatible with the serial peripheral interface (SPI) systems found on other Motorola products. Figure 20 shows a block diagram of the QSPI.


QSPI BLOCK
Figure 20 QSPI Block Diagram

### 7.4.1 QSPI Pins

Seven pins are associated with the QSPI. When not needed for a QSPI function, they can be configured as general-purpose I/O pins. The PCSO/SS pin can function as a peripheral chip select output, slave select input, or general-purpose I/O. Refer to Table 57 for QSPI input and output pins and their functions.

Table 57 QSPI Pins

| Pin Name(s) | Mnemonic(s) | Mode | Function |
| :---: | :---: | :---: | :--- |
| Master In Slave Out | MISO | Master <br> Slave | Serial Data Input to QSPI <br> Serial Data Output from QSPI |
| Master Out Slave In | MOSI | Master <br> Slave | Serial Data Output from QSPI <br> Serial Data Input to QSPI |
| Serial Clock | SCK | Master <br> Slave | Clock Output from QSPI <br> Clock Input to QSPI |
| Peripheral Chip Selects | PCS[3:1] | Master | Select Peripherals |
| Peripheral Chip Select <br> Slave Select | PCS0 | Master <br> Master <br> SS | Selects Peripheral <br> Causes mode fault <br> Initiates Serial Transfer |

### 7.4.2 QSPI Registers

The programmer's model for the QSPI submodule consists of the QSM global and pin control registers, four QSPI control registers, one status register, and the 80-byte QSPI RAM.

The CPU can read and write to registers and RAM. The four control registers must be initialized before the QSPI is enabled to ensure defined operation. SPCR1 should be written last because it contains QSPI enable bit SPE. Asserting this bit starts the QSPI. The QSPI control registers are reset to a defined state and can then be changed by the CPU. Reset values are shown below each register.

Table 58 shows a memory map of the QSPI.

Table 58 QSPI Memory Map

| Address | Name | Usage |
| :---: | :---: | :---: |
| \$YFFC18 | SPCR0 | QSPI Control Register 0 |
| \$YFFC1A | SPCR1 | QSPI Control Register 1 |
| \$YFFC1C | SPCR2 | QSPI Control Register 2 |
| \$YFFC1E | SPCR3 | QSPI Control Register 3 |
| \$YFFC1F | SPSR | QSPI Status Register |
| \$YFFD00 | RR[0:F] | QSPI Receive Data (16 Words) |
| \$YFFD20 | TR[0:F] | QSPI Transmit Data (16 Words) |
| \$YFFD40 | CR[0:F] | QSPI Command Control (8 Words) |

Writing a different value into any control register except SPCR2 while the QSPI is enabled disrupts operation. SPCR2 is buffered to prevent disruption of the current serial transfer. After completion of the current serial transfer, the new SPCR2 values become effective.

Writing the same value into any control register except SPCR2 while the QSPI is enabled has no effect on QSPI operation. Rewriting NEWQP[3:0] in SPCR2 causes execution to restart at the designated location.

SPCRO — QSPI Control Register 0

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSTR | WOMQ |  | BITS[3:0] |  | CPOL | CPHA |  |  |  | SPBR[7:0] |  |  |  |  |  |  |
| RESET: <br> 0 |  | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |

SPCRO contains parameters for configuring the QSPI before it is enabled. The CPU can read and write this register. The QSM has read-only access.

MSTR — Master/Slave Mode Select
$0=$ QSPI is a slave device and only responds to externally generated serial data.
$1=$ QSPI is system master and can initiate transmission to external SPI devices.
MSTR configures the QSPI for either master or slave mode operation. This bit is cleared on reset and may only be written by the CPU.

WOMQ - Wired-OR Mode for QSPI Pins
$0=$ Outputs have normal MOS drivers.
1 = Pins designated for output by DDRQS have open-drain drivers.
WOMQ allows the wired-OR function to be used on QSPI pins, regardless of whether they are used as general-purpose outputs or as QSPI outputs. WOMQ affects the QSPI pins regardless of whether the QSPI is enabled or disabled.

## BITS[3:0] — Bits Per Transfer

In master mode, when BITSE in a command is set, the BITS[3:0] field determines the number of data bits transferred. When BITSE is cleared, eight bits are transferred. Reserved values default to eight bits. In slave mode, the command RAM is not used and the setting of BITSE has no effect on QSP1 transfers. Instead, the BITS[3:0] field determines the number of bits the QSPI will receive during each transfer before storing the received data.

Table 59 shows the number of bits per transfer.

Table 59 Bits Per Transfer

| BITS[3:0] | Bits per Transfer |
| :---: | :---: |
| 0000 | 16 |
| 0001 | Reserved |
| 0010 | Reserved |
| 0011 | Reserved |
| 0100 | Reserved |
| 0101 | Reserved |
| 0110 | Reserved |
| 0111 | Reserved |
| 1000 | 8 |
| 1001 | 9 |
| 1010 | 10 |
| 1011 | 11 |
| 1100 | 12 |
| 1101 | 13 |
| 1110 | 14 |
| 1111 | 15 |

CPOL - Clock Polarity
$0=$ The inactive state value of SCK is logic level zero.
1 = The inactive state value of SCK is logic level one.
CPOL is used to determine the inactive state value of the serial clock (SCK). It is used with CPHA to produce a desired clock/data relationship between master and slave devices.

CPHA - Clock Phase
$0=$ Data is captured on the leading edge of SCK and changed on the following edge of SCK.
$1=$ Data is changed on the leading edge of SCK and captured on the following edge of SCK. CPHA determines which edge of SCK causes data to change and which edge causes data to be captured. CPHA is used with CPOL to produce a desired clock/data relationship between master and slave devices. CPHA is set at reset.

SPBR[7:0] — Serial Clock Baud Rate
The QSPI uses a modulus counter to derive SCK baud rate from the MCU system clock. Baud rate is selected by writing a value from 2 to 255 into the SPBR[7:0] field. The following equation determines the SCK baud rate:

$$
\begin{gathered}
\text { SCK Baud Rate }=\frac{\text { System Clock }}{2 \times \text { SPBR[7:0] }} \\
\text { or } \\
\text { SPBR[7:0] }=\frac{\text { System Clock }}{2 \times \text { SCK Baud Rate Desired }}
\end{gathered}
$$

Giving $\operatorname{SPBR}[7: 0]$ a value of zero or one disables the baud rate generator. SCK is disabled and assumes its inactive state value. No serial transfers occur. At reset, baud rate is initialized to one eighth of the system clock frequency.

SPRC1 — QSPI Control Register 1 \$YFFC1A


SPCR1 contains parameters for configuring the QSPI before it is enabled. The CPU can read and write this register, but the QSM has read access only, except for SPE, which is automatically cleared by the QSPI after completing all serial transfers, or when a mode fault occurs.

SPE — QSPI Enable
0 = QSPI is disabled. QSPI pins can be used for general-purpose I/O.
$1=$ QSPI is enabled. Pins allocated by PQSPAR are controlled by the QSPI.
DSCKL[6:0] — Delay before SCK
When the DSCK bit in command RAM is set, this field determines the length of delay from PCS valid to SCK transition. PCS can be any of the four peripheral chip-select pins. The following equation determines the actual delay before SCK:

$$
\text { PCS to SCK Delay }=\frac{\text { DSCKL[6:0] }}{\text { System Clock }}
$$

where DSCKL[6:0] equals $\{1,2,3, \ldots, 127\}$.
When the DSCK value of a queue entry equals zero, then DSCKL[6:0] is not used. Instead, the PCS valid-to-SCK transition is one-half SCK period.

DTL[7:0] — Length of Delay after Transfer
When the DT bit in command RAM is set, this field determines the length of delay after serial transfer. The following equation is used to calculate the delay:

$$
\text { Delay after Transfer }=\frac{32 \times \text { DTL[7:0] }}{\text { System Clock }}
$$

where DTL equals $\{1,2,3, \ldots, 255\}$.
A zero value for DTL[7:0] causes a delay-after-transfer value of 8192/System Clock.
If DT equals zero, a standard delay is inserted.

$$
\text { Standard Delay after Transfer }=\frac{17}{\text { System Clock }}
$$

Delay after transfer can be used to provide a peripheral deselect interval. A delay can also be inserted between consecutive transfers to allow serial A/D converters to complete conversion.

SPCR2 — QSPI Control Register 2
\$YFFC1C

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SPIFIE | WREN | WRTO | 0 |  | ENDQP[3:0] | 0 | 0 | 0 | 0 |  | NEWQP[3:0] |  |  |  |

RESET:
$\begin{array}{lllllllllllllllllll}0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0\end{array}$
SPCR2 contains QSPI configuration parameters. The CPU can read and write this register; the QSM has read access only. Writes to SPCR2 are buffered. A write to SPCR2 that changes a bit value while the QSPI is operating is ineffective on the current serial transfer, but becomes effective on the next serial transfer. Reads of SPCR2 return the current value of the register, not of the buffer.

SPIFIE — SPI Finished Interrupt Enable
0 = QSPI interrupts disabled
1 = QSPI interrupts enabled
SPIFIE enables the QSPI to generate a CPU interrupt upon assertion of the status flag SPIF.
WREN - Wrap Enable
$0=$ Wraparound mode disabled
1 = Wraparound mode enabled
WREN enables or disables wraparound mode.

## WRTO - Wrap To

When wraparound mode is enabled, after the end of queue has been reached, WRTO determines which address the QSPI executes.

Bit 12 - Not Implemented
ENDQP[3:0] — Ending Queue Pointer
This field contains the last QSPI queue address.
Bits [7:4] — Not Implemented
NEWQP[3:0] - New Queue Pointer Value
This field contains the first QSPI queue address.


| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

SPCR3 contains QSPI configuration parameters. The CPU can read and write SPCR3, but the QSM has read-only access.

Bits [15:11] — Not Implemented

## LOOPQ — QSPI Loop Mode

$0=$ Feedback path disabled
1 = Feedback path enabled
LOOPQ controls feedback on the data serializer for testing.
HMIE - HALTA and MODF Interrupt Enable
$0=$ HALTA and MODF interrupts disabled
$1=$ HALTA and MODF interrupts enabled
HMIE controls CPU interrupts caused by the HALTA status flag or the MODF status flag in SPSR.
HALT - Halt
0 = Halt not enabled
1 = Halt enabled
When HALT is asserted, the QSPI stops on a queue boundary. It is in a defined state from which it can later be restarted.

SPSR — QSPI Status Register
\$YFFC1F

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | SPCR3 |  | SPIF | MODF | HALTA | 0 | 0 | CPTQP[3:0] |  |  |  |  |  |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |

SPSR contains QSPI status information. Only the QSPI can assert the bits in this register. The CPU reads this register to obtain status information and writes it to clear status flags.

SPIF — QSPI Finished Flag
$0=$ QSPI not finished
1 = QSPI finished
SPIF is set after execution of the command at the address in ENDQP[3:0].
MODF - Mode Fault Flag
0 = Normal operation
1 = Another SPI node requested to become the network SPI master while the QSPI was enabled in master mode ( $\overline{\mathrm{SS}}$ input taken low).
The QSPI asserts MODF when the QSPI is the serial master ( $M S T R=1$ ) and the $\overline{S S}$ input pin is negated by an external driver.

HALTA - Halt Acknowledge Flag
$0=$ QSPI not halted
1 = QSPI halted
HALTA is asserted when the QSPI halts in response to CPU assertion of HALT.
Bit 4 - Not Implemented

## CPTQP[3:0] - Completed Queue Pointer

CPTQP[3:0] points to the last command executed. It is updated when the current command is complete. When the first command in a queue is executing, CPTQP[3:0] contains either the reset value (\$0) or a pointer to the last command completed in the previous queue.

### 7.4.3 QSPI RAM

The QSPI contains an 80-byte block of dual-access static RAM that is used by both the QSPI and the CPU. The RAM is divided into three segments: receive data, transmit data, and command control data. Receive data is information received from a serial device external to the MCU. Transmit data is information stored by the CPU for transmission to an external peripheral. Command control data is used to perform the transfer.

Figure 21 displays the organization of the RAM.


Figure 21 QSPI RAM

Once the CPU has set up the queue of QSPI commands and enabled the QSPI, the QSPI can operate independently of the CPU. The QSPI executes all of the commands in its queue, sets a flag indicating that it is finished, and then either interrupts the CPU or waits for CPU intervention. It is possible to execute a queue of commands repeatedly without CPU intervention.

RR[0:F] — Receive Data RAM
\$YFFD00
Data received by the QSPI is stored in this segment. The CPU reads this segment to retrieve data from the QSPI. Data stored in receive RAM is right-justified. Unused bits in a receive queue entry are set to zero by the QSPI upon completion of the individual queue entry. The CPU can access the data using byte, word, or long-word addressing.

The CPTQP[3:0] value in SPSR shows which queue entries have been executed. The CPU uses this information to determine which locations in receive RAM contain valid data before reading them.

TR[0:F] — Transmit Data RAM
\$YFFD20
Data that is to be transmitted by the QSPI is stored in this segment. The CPU usually writes one word of data into this segment for each queue command to be executed.

Information to be transmitted must be written to transmit data RAM in a right-justified format. The QSPI cannot modify information in the transmit data RAM. The QSPI copies the information to its data serializer for transmission. Information remains in transmit RAM until overwritten.

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CONT | BITSE | DT | DSCK | PCS3 | PCS2 | PCS1 | PCS0 $^{1}$ |


| CONT | BITSE | DT | DSCK | PCS3 | PCS2 | PCS1 | PCS0 $^{1}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

## COMMAND CONTROL

1. The PCS0 bit represents the dual-function PCS0/SS.

Command RAM is used by the QSPI when in master mode. The CPU writes one byte of control information to this segment for each QSPI command to be executed. The QSPI cannot modify information in command RAM.

Command RAM consists of 16 bytes. Each byte is divided into two fields. The peripheral chip-select field enables peripherals for transfer. The command control field provides transfer options.

A maximum of 16 commands can be in the queue. Queue execution by the QSPI proceeds from the address in NEWQP[3:0] through the address in ENDQP[3:0]. (Both of these fields are in SPCR2).

CONT - Continue
$0=$ Control of chip selects returned to PORTQS after transfer is complete.
1 = Peripheral chip selects remain asserted after transfer is complete.
BITSE - Bits per Transfer Enable
$0=8$ bits
1 = Number of bits set in BITS[3:0] field of SPCR0
DT — Delay after Transfer
The QSPI provides a variable delay at the end of serial transfer to facilitate the interface with peripherals that have a latency requirement. The delay between transfers is determined by the SPCR1 DTL[6:0] field.

DSCK - PCS to SCK Delay
0 = PCS valid to SCK transition is one-half SCK.
1 = SPCR1 DSCKL[6:0] field specifies delay from PCS valid to SCK.
PCS[3:0] — Peripheral Chip Select
Use peripheral chip-select bits to select an external device for serial data transfer. More than one peripheral chip select can be activated at a time, and more than one peripheral chip can be connected to each PCS pin, provided that proper fanout is observed.

### 7.4.4 Operating Modes

The QSPI operates in either master or slave mode. Master mode is used when the MCU originates data transfers. Slave mode is used when an external device initiates serial transfers to the MCU through the QSPI. Switching between the modes is controlled by MSTR in SPCRO. Before entering either mode, appropriate QSM and QSPI registers must be properly initialized.

In master mode, the QSPI executes a queue of commands defined by control bits in each command RAM queue entry. Chip-select pins are activated, data is transmitted from transmit RAM and received into receive RAM.

In slave mode, operation proceeds in response to $\overline{\mathrm{SS}}$ pin activation by an external bus master. Operation is similar to master mode, but no peripheral chip selects are generated, and the number of bits transferred is controlled in a different manner. When the QSPI is selected, it automatically executes the next queue transfer to exchange data with the external device correctly.

Although the QSPI inherently supports multi-master operation, no special arbitration mechanism is provided. A mode fault flag (MODF) indicates a request for SPI master arbitration. System software must provide arbitration. Note that unlike previous SPI systems, MSTR is not cleared by a mode fault being set, nor are the QSPI pin output drivers disabled. The QSPI and associated output drivers must be disabled by clearing SPE in SPCR1.

### 7.5 SCI Submodule

The SCI submodule is used to communicate with external devices through an asynchronous serial bus. The SCI is fully compatible with the SCI systems found on other Motorola MCUs, such as the M68HC11 and M68HC05 Families.

### 7.5.1 SCI Pins

There are two unidirectional pins associated with the SCI. The SCI controls the transmit data (TXD) pin when enabled, whereas the receive data (RXD) pin remains a dedicated input pin to the SCI. TXD is available as a general-purpose I/O pin when the SCI transmitter is disabled. When used for I/O, TXD can be configured either as input or output, as determined by QSM register DDRQS.

Table 60 shows SCI pins and their functions.

Table 60 SCI Pins

| Pin Names | Mnemonics | Mode | Function |
| :---: | :---: | :---: | :---: |
| Receive Data | RXD | Receiver Disabled <br> Receiver Enabled | Not Used |
| Serial Data Input to SCI |  |  |  |

### 7.5.2 SCI Registers

The SCI programming model includes QSM global and pin control registers, and four SCI registers. There are two SCl control registers, one status register, and one data register. All registers can be read or written at any time by the CPU.

Changing the value of SCI control bits during a transfer operation may disrupt operation. Before changing register values, allow the transmitter to complete the current transfer, then disable the receiver and transmitter. Status flags in the SCSR may be cleared at any time.

SCCRO - SCI Control Register 0

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | SCBR[12:0] |  |  |  |  |  |  |  |  |  |  |  |  |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |

SCCRO contains a baud rate selection parameter. Baud rate must be set before the SCI is enabled. The CPU can read and write this register at any time.

Bits [15:13] — Not Implemented

## SCBR[12:0] — Baud Rate

SCI baud rate is programmed by writing a 13 -bit value to $B R$. The baud rate is derived from the MCU system clock by a modulus counter.

The SCI receiver operates asynchronously. An internal clock is necessary to synchronize with an incoming data stream. The SCl baud rate generator produces a receiver sampling clock with a frequency 16 times that of the expected baud rate of the incoming data. The SCI determines the position of bit boundaries from transitions within the received waveform, and adjusts sampling points to the proper positions within the bit period. Receiver sampling rate is always 16 times the frequency of the SCl baud rate, which is calculated as follows:

$$
\begin{gathered}
\text { SCI Baud Rate }=\frac{\text { System Clock }}{32 \times \text { SCBR[12:0] }} \\
\text { or } \\
\text { SCBR[12:0] }=\frac{\text { System Clock }}{32 \times \text { SCI Baud Rate Desired }}
\end{gathered}
$$

where SCBR[12:0] is in the range $\{1,2,3, \ldots, 8191\}$
Writing a value of zero to SCBR[12:0] disables the baud rate generator.
Table 61 lists the SCBR[12:0] settings for standard and maximum baud rates using a 16.78 MHz system clock.

Table 61 SCI Baud Rates

| Nominal <br> Baud Rate | Actual Rate with <br> 16.78 MHz Clock | SCBR[12:0] Value |
| :---: | :---: | :---: |
| 64 | 64.0 | $\$ 1 \mathrm{~B} 8 \mathrm{~B}$ |
| 110 | 110.0 | $\$ 1006$ |
| 300 | 300.0 | $\$ 05 \mathrm{E} 0$ |
| 600 | 600.1 | $\$ 02 \mathrm{F0}$ |
| 1200 | 1200.1 | $\$ 0178$ |
| 2400 | 2400.3 | $\$ 00 \mathrm{BC}$ |
| 4800 | 4800.5 | $\$ 005 \mathrm{E}$ |
| 9600 | 9601.1 | $\$ 002 \mathrm{~F}$ |
| 19200 | 18802.1 | $\$ 0018$ |
| 38400 | 37604.2 | $\$ 000 \mathrm{C}$ |
| 76800 | 75208.3 | $\$ 0006$ |
| Maximum Rate | 451250.0 | $\$ 0001$ |


| 15 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 14 |  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | LOOPS

SCCR1 contains SCI configuration parameters. The CPU can read and write this register at any time. The SCI can modify RWU in some circumstances. In general, interrupts enabled by these control bits are cleared by reading SCSR, then reading (for receiver status bits) or writing (for transmitter status bits) SCDR.

Bit 15 - Not Implemented
LOOPS - Loop Mode
$0=$ Normal SCI operation, no looping, feedback path disabled
$1=$ Test SCI operation, looping, feedback path enabled
LOOPS controls a feedback path on the data serial shifter. When loop mode is enabled, SCI transmitter output is fed back into the receive serial shifter. TXD is asserted (idle line). Both transmitter and receiver must be enabled before entering loop mode.

WOMS - Wired-OR Mode for SCI Pins
$0=$ If configured as an output, TXD is a normal CMOS output.
$1=$ If configured as an output, TXD is an open-drain output.
WOMS determines whether the TXD pin is an open-drain output or a normal CMOS output. This bit is used only when TXD is an output. If TXD is used as a general-purpose input pin, WOMS has no effect.

ILT - Idle-Line Detect Type
$0=$ Short idle-line detect (start count on first one)
1 = Long idle-line detect (start count on first one after stop bit(s))
PT - Parity Type
0 = Even parity
1 = Odd parity
When parity is enabled, PT determines whether parity is even or odd for both the receiver and the transmitter.

PE - Parity Enable
$0=$ SCI parity disabled
1 = SCI parity enabled
PE determines whether parity is enabled or disabled for both the receiver and the transmitter. If the received parity bit is not correct, the SCI sets the PF error flag in SCSR.

When PE is set, the most significant bit (MSB) of the data field is used for the parity function, which results in either seven or eight bits of user data, depending on the condition of M bit. Table 62 lists the available choices.

Table 62 Parity Enable Data Bit Selection

| $\mathbf{M}$ | PE | Result |
| :---: | :---: | :---: |
| 0 | 0 | 8 Data Bits |
| 0 | 1 | 7 Data Bits, 1 Parity Bit |
| 1 | 0 | 9 Data Bits |
| 1 | 1 | 8 Data Bits, 1 Parity Bit |

M - Mode Select
$0=$ SCI frame: 1 start bit, 8 data bits, 1 stop bit (10 bits total)
1 = SCI frame: 1 start bit, 9 data bits, 1 stop bit (11 bits total)
WAKE - Wakeup by Address Mark
$0=$ SCI receiver awakened by idle-line detection
$1=$ SCI receiver awakened by address mark (last bit set)
TIE — Transmit Interrupt Enable
0 = SCI TDRE interrupts inhibited
1 = SCI TDRE interrupts enabled
TCIE - Transmit Complete Interrupt Enable
$0=$ SCI TC interrupts inhibited
$1=$ SCI TC interrupts enabled
RIE — Receiver Interrupt Enable
$0=$ SCI RDRF interrupt inhibited
1 = SCI RDRF interrupt enabled
ILIE - Idle-Line Interrupt Enable
0 = SCI IDLE interrupts inhibited
1 = SCI IDLE interrupts enabled
TE - Transmitter Enable
$0=$ SCI transmitter disabled (TXD pin may be used as I/O)
$1=$ SCI transmitter enabled (TXD pin dedicated to SCI transmitter)
The transmitter retains control of the TXD pin until completion of any character transfer that was in progress when TE is cleared.

RE - Receiver Enable
$0=S C I$ receiver disabled (status bits inhibited)
$1=$ SCI receiver enabled
RWU - Receiver Wakeup
$0=$ Normal receiver operation (received data recognized)
1 = Wakeup mode enabled (received data ignored until awakened)
Setting RWU enables the wakeup function, which allows the SCI to ignore received data until awakened by either an idle line or address mark (as determined by WAKE). When in wakeup mode, the receiver status flags are not set, and interrupts are inhibited. This bit is cleared automatically (returned to normal mode) when the receiver is awakened.

SBK - Send Break
$0=$ Normal operation
1 = Break frame(s) transmitted after completion of current frame
SBK provides the ability to transmit a break code from the SCI. If the SCI is transmitting when SBK is set, it will transmit continuous frames of zeros after it completes the current frame, until SBK is cleared. If SBK is toggled (one to zero in less than one frame interval), the transmitter sends only one or two break frames before reverting to idle line or beginning to send data.

# SCSR - SCI Status Register 

\$YFFCOC


SCSR contains flags that show SCI operational conditions. These flags can be cleared either by hardware or by a special acknowledgment sequence. The sequence consists of SCSR read with flags set, followed by SCDR read (write in the case of TDRE and TC). A long-word read can consecutively access both SCSR and SCDR. This action clears receive status flag bits that were set at the time of the read, but does not clear TDRE or TC flags.

If an internal SCI signal for setting a status bit comes after the CPU has read the asserted status bits, but before the CPU has written or read register SCDR, the newly set status bit is not cleared. SCSR must be read again with the bit set. Also, SCDR must be written or read before the status bit is cleared.

Reading either byte of SCSR causes all 16 bits to be accessed. Any status bit already set in either byte will be cleared on a subsequent read or write of register SCDR.

TDRE - Transmit Data Register Empty Flag
$0=$ Register TDR still contains data to be sent to the transmit serial shifter.
1 = A new character can now be written to the transmit data register.
TDRE is set when the byte in the transmit data register is transferred to the transmit serial shifter. If TDRE is zero, transfer has not occurred and a write to the transmit data register will overwrite the previous value. New data is not transmitted if the transmit data register is written without first clearing TDRE.

TC — Transmit Complete Flag
$0=$ SCI transmitter is busy
$1=$ SCI transmitter is idle
TC is set when the transmitter finishes shifting out all data, queued preambles (mark/idle line), or queued breaks (logic zero). The interrupt can be cleared by reading SCSR when TC is set and then by writing the transmit data register of SCDR.

RDRF - Receive Data Register Full Flag
$0=$ Receive data register is empty or contains previously read data.
1 = Receive data register contains new data.
RDRF is set when the content of the receive serial shifter is transferred to the receive data register. If one or more errors are detected in the received word, flag(s) NF, FE, and/or PF are set within the same clock cycle.

RAF - Receiver Active Flag
$0=\mathrm{SCl}$ receiver is idle
1 = SCI receiver is busy
RAF indicates whether the SCI receiver is busy. It is set when the receiver detects a possible start bit and is cleared when the chosen type of idle line is detected. RAF can be used to reduce collisions in systems with multiple masters.

IDLE - Idle-Line Detected Flag
$0=\mathrm{SCI}$ receiver did not detect an idle-line condition.
$1=$ SCI receiver detected an idle-line condition.
IDLE is disabled when RWU in SCCR1 is set. IDLE is set when the SCI receiver detects the idle-line condition specified by ILT in SCCR1. If cleared, IDLE will not set again until after RDRF is set. RDRF is set when a break is received, so that a subsequent idle line can be detected.

OR — Overrun Error Flag
$0=$ RDRF is cleared before new data arrives.
$1=$ RDRF is not cleared before new data arrives.
OR is set when a new byte is ready to be transferred from the receive serial shifter to the receive data register, and RDRF is still set. Data transfer is inhibited until OR is cleared. Previous data in receive data register remains valid, but data received during overrun condition (including the byte that set OR) is lost.

## NF - Noise Error Flag

$0=$ No noise detected on the received data
1 = Noise occurred on the received data
NF is set when the SCI receiver detects noise on a valid start bit, on any data bit, or on a stop bit. It is not set by noise on the idle line or on invalid start bits. Each bit is sampled three times. If none of the three samples are the same logic level, the majority value is used for the received data value, and NF is set. NF is not set until an entire frame is received and RDRF is set.

## FE - Framing Error Flag

$0=$ No framing error on the received data.
1 = Framing error or break occurred on the received data.
FE is set when the SCI receiver detects a zero where a stop bit was to have occurred. FE is not set until the entire frame is received and RDRF is set. A break can also cause FE to be set. It is possible to miss a framing error if RXD happens to be at logic level one at the time the stop bit is expected.

PF - Parity Error Flag $0=$ No parity error on the received data 1 = Parity error occurred on the received data
PF is set when the SCI receiver detects a parity error. PF is not set until the entire frame is received and RDRF is set.

SCDR — SCI Data Register
\$YFFCOE

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | R8/T8 | R7/T7 | R6/T6 | R5/T5 | R4/T4 | R3/T3 | R2/T2 | R1/T1 | RO/T0 |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | U | U | U | U | U | U | U | U | U |

SCDR contains two data registers at the same address. The receive data register is a read-only register that contains data received by the SCI. The data comes into the receive serial shifter and is transferred to the receive data register. The transmit data register is a write-only register that contains data to be transmitted. The data is first written to the transmit data register, then transferred to the transmit serial shifter, where additional format bits are added before transmission. R[7:0]/ $\mathrm{T}[7: 0]$ contain either the first eight data bits received when SCDR is read, or the first eight data bits to be transmitted when SCDR is written. R8/T8 are used when the SCI is configured for 9-bit operation. When it is configured for 8 -bit operation, they have no meaning or effect.

## 8 Standby RAM Module

The standby RAM module (SRAM) provides 2 Kbytes of fast RAM that is especially useful for system stacks and variable storage. The SRAM has a dedicated power supply pin so that memory content can be preserved when the MCU is powered down.

### 8.1 Overview

The SRAM module consists of a control register block that is located at a fixed range of addresses in MCU address space, and a 2 Kbyte array of two bus cycle static RAM that can be mapped to any 2 Kbyte boundary in MCU address space. SRAM control registers are located at addresses \$YFFB00-YFFB08.

The module responds to program and data space accesses. Data can be read or written in bytes, words, or long words. The RAM array must not be mapped so that array addresses overlap module control register addresses, as overlap makes the registers inaccessible.

SRAM is powered by $V_{D D}$ in normal operation. During power-down, SRAM contents are maintained by power from the $\mathrm{V}_{\text {STBY }}$ input. Power switching between sources is automatic.

Table 63 shows the SRAM address map.

Table 63 SRAM Address Map

| Address | $\mathbf{1 5}$ | $\mathbf{8} \mathbf{7}$ |
| :---: | :---: | :---: |
| \$YFFB00 $^{1}$ | RAM MODULE CONFIGURATION REGISTER (RAMMCR) |  |
| \$YFFB02 | RAM TEST REGISTER (RAMTST) |  |
| \$YFFB04 | RAM ARRAY BASE ADDRESS REGISTER HIGH (RAMBAH) |  |
| \$YFFB06 | RAM ARRAY BASE ADDRESS REGISTER LOW (RAMBAL) |  |

1. $\mathrm{Y}=\mathrm{M} 111$, where M is the logic state of the module mapping (MM) bit in SCIMCR.

### 8.2 SRAM Register Block

There are four SRAM control registers: the SRAM module configuration register (RAMMCR), the SRAM test register (RAMTST), and the SRAM array base address registers (RAMBAH/RAMBAL).

### 8.3 SRAM Registers

SRAM responds to both program and data space accesses based on the value in the RASP field in RAMMCR. This allows code to be executed from RAM.

| RAMM | - | M | dul | onfig | atio | gister |  |  |  |  |  |  |  | B00 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 15 | 14 | 13 | 12 | 11 | 10 | 98 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| STOP | 0 | 0 | 0 | RLCK | 0 | RASP[1:0] |  |  |  |  |  |  |  |  |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 | 0 | 0 | 0 | 0 | 0 | 11 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

Use RAMMCR to determine whether the RAM is in STOP mode or normal mode. RAMMCR can determine in which space the array resides and also controls access to the base array registers. Reads of unimplemented bits always return zeros. Writes do not affect unimplemented bits.

STOP - Stop Control
$0=$ RAM array operates normally.
1 = RAM array enters low-power stop mode.
This bit controls whether the RAM array is in stop mode or normal operation. Reset state is one, leaving the array configured for LPSTOP operation. In stop mode, the array retains its contents, but cannot be read or written by the CPU. This bit can be read or written at any time.

RLCK — RAM Base Address Lock
$0=$ SRAM base address registers can be written from IMB
1 = SRAM base address registers are locked
RLCK defaults to zero on reset. It can be written to one once.
RASP[1:0] - RAM Array Space
This field limits access to the SRAM array in microcontrollers that support separate user and supervisor operating modes. Because the CPU16 operates in supervisor mode only, RASP1 has no effect. Refer to Table 64.

Table 64 RASP Encoding

| RASP | Space |
| :---: | :---: |
| X0 | Program and Data |
| X1 | Program |

RAMTST - RAM Test Register
RAMTST is for factory test only. Reads of this register return zeros and writes have no effect.

RAMBAH - Array Base Address Register High
\$YFFB04


RAMBAL — Array Base Address Register Low \$YFFB06

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { ADDR } \\ 15 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 14 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 13 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 12 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 11 \end{gathered}$ | NOT USED |  |  |  |  |  |  |  |  |  |  |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

RAMBAH and RAMBAL specify an SRAM base address in the system memory map. They can only be written while the SRAM is in low-power mode (RAMMCR STOP = 1 , the default out of reset) and the base address lock is disabled (RAMMCR RLCK $=0$, the default out of reset). This prevents accidental remapping of the array. Because the CPU16 drives ADDR[23:20] to the same logic level as ADDR19, the values of the RAMBAH ADDR[23:20] fields must match the value of the ADDR19 field for the array to be accessible.

### 8.4 SRAM Operation

There are five SRAM operating modes. They include the following:

1. The RAM module is in normal mode when powered by $\mathrm{V}_{\mathrm{DD}}$. The array can be accessed by byte, word, or long word. A byte or aligned word (high-order byte is at an even address) access only takes one bus cycle or two system clocks. A long word or misaligned word access requires two bus cycles.
2. Standby mode is intended to preserve RAM contents when $V_{D D}$ is removed. SRAM contents are maintained by a power source connected to the $\mathrm{V}_{\text {STBY }}$ pin. The standby voltage is referred to as $\mathrm{V}_{\mathrm{SB}}$. Circuitry within the SRAM module switches to the higher of $\mathrm{V}_{\mathrm{DD}}$ or $V_{S B}$ with no loss of data. When SRAM is powered from the $V_{S T B Y}$ pin, access to the array is not guaranteed. If standby operation is not desired, connect the $V_{\text {STBY }}$ pin to $V_{\text {SS }}$.
3. Reset mode allows the CPU to complete the current bus cycle before resetting. When a synchronous reset occurs while a byte or word SRAM access is in progress, the access is completed. If reset occurs during the first word access of a long-word operation, only the first word access is completed. If reset occurs during the second word access of a long word operation, the entire access is completed. Data being read from or written to the RAM may be corrupted by asynchronous reset.
4. Test mode is used for factory testing of the RAM array.
5. Writing the STOP bit of RAMMCR causes the SRAM module to enter stop mode. The RAM array is disabled which, if necessary, allows external logic to decode SRAM addresses but all data is retained. If $\mathrm{V}_{\mathrm{DD}}$ falls below $\mathrm{V}_{\mathrm{SB}}$, internal circuitry switches to $\mathrm{V}_{\mathrm{SB}}$, as in standby mode. Exit the stop mode by clearing the STOP bit.

## 9 Flash EEPROM Module

The MC68HC916X1 contains two flash electrically erasable programmable read-only memory (EEPROM) modules: a 16 Kbyte module and a 32 Kbyte module.

### 9.1 Overview

The flash EEPROM modules serve as nonvolatile, fast-access, electrically erasable and programmable ROM-emulation memory. The modules can contain program code (e.g., operating system kernels and standard subroutines) which must execute at high speed or is frequently executed, or static data which is read frequently. The flash EEPROM supports both byte and word reads. It is capable of responding to back-to-back IMB accesses to provide two bus cycle (four system clock) access for aligned long words. It can also be programmed to insert up to three wait states to accommodate migration from slower external development memory to onboard flash EEPROM without the need for retiming the system.

The 16 Kbyte flash EEPROM array can begin on any 16 Kbyte boundary, and the 32 Kbyte array can begin on any 32 Kbyte boundary. The two arrays can be configured to appear as a single contiguous memory block, with the 16 Kbyte array immediately preceding or immediately following the 32 Kbyte array.

Pulling data bus pin DATA14 low during reset disables both the 16- and 32-Kbyte flash EEPROM modules and places them in stop mode.

Either of the flash EEPROM modules can be configured to generate bootstrap information on system reset. Bootstrap information consists of the initial program counter and stack pointer values for the CPU16.

The flash EEPROM and its control bits are erasable and programmable under software control. Program/erase voltage must be supplied via external $\mathrm{V}_{\text {FPE }}$ pins. Data is programmed in byte or word aligned fashion. Multiple word programming is not supported. The flash EEPROM modules support bulk erase only, and have a minimum program-erase life of 100 cycles.

The flash EEPROM modules have hardware interlocks which protect stored data from corruption by accidental enabling of the program/erase voltage to the flash EEPROM arrays. With the hardware interlocks, inadvertent programming or erasure is highly unlikely.

### 9.2 Address Map

Table 65 shows the flash EEPROM module address map.

Table 65 Flash EEPROM Address Map

| Address | Register | Module |
| :---: | :---: | :---: |
| \$YFF800 ${ }^{1}$ | FLASH EEPROM MODULE CONFIGURATION (FEE1MCR) | 16 KBYTE FLASH EEPROM |
| \$YFF802 | FLASH EEPROM TEST REGISTER (FEE1TST) |  |
| \$YFF804 | FLASH EEPROM BASE ADDRESS HIGH (FEE1BAH) |  |
| \$YFF806 | FLASH EEPROM BASE ADDRESS LOW (FEE1BAL) |  |
| \$YFF808 | FLASH EEPROM CONTROL REGISTER (FEE1CTL) |  |
| \$YFF80A | RESERVED |  |
| \$YFF80C | RESERVED |  |
| \$YFF80E | RESERVED |  |
| \$YFF810 | FLASH EEPROM BOOTSTRAP WORD 0 (FEE1BS0) |  |
| \$YFF812 | FLASH EEPROM BOOTSTRAP WORD 1 (FEE1BS1) |  |
| \$YFF814 | FLASH EEPROM BOOTSTRAP WORD 2 (FEE1BS2) |  |
| \$YFF816 | FLASH EEPROM BOOTSTRAP WORD 3 (FEE1BS3) |  |
| \$YFF818 | RESERVED |  |
| \$YFF81A | RESERVED |  |
| \$YFF81C | RESERVED |  |
| \$YFF81E | RESERVED |  |
| \$YFF820 | FLASH EEPROM MODULE CONFIGURATION (FEE2MCR) | 32 KBYTE FLASH EEPROM |
| \$YFF822 | FLASH EEPROM TEST REGISTER (FEE2TST) |  |
| \$YFF824 | FLASH EEPROM BASE ADDRESS HIGH (FEE2BAH) |  |
| \$YFF826 | FLASH EEPROM BASE ADDRESS LOW (FEE2BAL) |  |
| \$YFF828 | FLASH EEPROM CONTROL REGISTER (FEE2CTL) |  |
| \$YFF82A | RESERVED |  |
| \$YFF82C | RESERVED |  |
| \$YFF82E | RESERVED |  |
| \$YFF830 | FLASH EEPROM BOOTSTRAP WORD 0 (FEE2BS0) |  |
| \$YFF832 | FLASH EEPROM BOOTSTRAP WORD 1 (FEE2BS1) |  |
| \$YFF834 | FLASH EEPROM BOOTSTRAP WORD 2 (FEE2BS2) |  |
| \$YFF836 | FLASH EEPROM BOOTSTRAP WORD 3 (FEE2BS3) |  |
| \$YFF838 | RESERVED |  |
| \$YFF83A | RESERVED |  |
| \$YFF83C | RESERVED |  |
| \$YFF83E | RESERVED |  |

1. $Y=M 111$, where $M$ is the logic state of the module mapping (MM) bit in the SCIMCR.

### 9.3 Flash EEPROM Control Block

Each flash EEPROM module has a 32 byte control block with five registers to control flash EEPROM operation: the flash EEPROM module configuration register (FEE1MCR, FEE2MCR), the flash EEPROM test register (FEE1TST, FEE2TST), the flash EEPROM array base address registers (FEE1BAH, FEE2BAH, and FEE1BAL, FEE2BAL), and the flash EEPROM control register (FEE1CTL, FEE2CTL). Four additional flash EEPROM words in the control block can contain bootstrap information for use during reset. Control registers are located in supervisor data space.

The control register blocks for the 16 Kbyte and 32 Kbyte flash EEPROM modules start at locations \$YFF800 and \$YFF820, respectively. The following register descriptions apply to the corresponding register in either control block. References to FEExMCR, for example, apply to both FEE1MCR (in the 16 Kbyte module) and FEE2MCR (in the 32 Kbyte module.)

A number of control register bits have associated bits in "shadow" registers. The values of the shadow bits determine the reset states of the control register bits. Shadow registers are programmed or erased in the same manner as a location in the array, using the address of the corresponding control registers. When a shadow register is programmed, the data is not written to the corresponding control register. The new data is not copied into the control register until the next reset. The contents of shadow registers are erased when the array is erased.

Configuration information is specified and programmed independently of the array. After reset, registers in the control block that contain writable bits can be modified. Writes to these registers do not affect the associated shadow register. Certain registers can be written only when LOCK $=0$ or STOP = 1 in FEExMCR.

### 9.4 Flash EEPROM Array

The base address registers specify the starting address of the flash EEPROM array. The user programs the reset base address. The base address of the 16 Kbyte array must be on a 16 Kbyte boundary; the base address of the 32 Kbyte array must be on a 32 Kbyte boundary. Behavior will be indeterminate if one flash EEPROM array overlaps the other.

The base address must also be set so that an array does not overlap a flash EEPROM control block in the data space memory map. If an array does overlap a control block, accesses to the 32 bytes in the array that is overlapped are ignored, allowing the flash EEPROM control blocks to remain accessible. If the array overlaps the control block of another module, the results will be indeterminate.

### 9.5 Flash EEPROM Registers

In the following register diagrams, bits with reset states determined by shadow bits are shaded, and the reset state is annotated "SB".
FEE1MCR, FEE2MCR - Flash EEPROM Module Configuration Registers
\$YFF800, \$YFF820

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| STOP | FRZ | 0 | BOOT | LOCK | 0 | ASPC[1:0] | WAIT[1:0] | 0 | 0 | 0 | 0 | 0 | 0 |  |  |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| DATA14 <br> + SB | 0 | 0 | SB | SB | 0 | SB | SB | SB | SB | 0 | 0 | 0 | 0 | 0 | 0 |

The flash EEPROM module configuration registers (FEE1MCR, FEE2MCR) control module configuration. This register can be written only when LOCK $=0$. All active bits in the FEExMCR take values from the associated shadow register during reset.

STOP — Stop Mode Control
$0=$ Normal operation
1 = Low-power stop operation
STOP can be set either by pulling data bus pin DATA14 low during reset (for both flash EEPROM modules) or by the corresponding shadow bit. The array can be re-enabled by clearing STOP. If STOP is set during programming or erasing, the program/erase voltage is automatically turned off. However, the ENPE control bit in FEExCTL remains set. When STOP is cleared, the program/erase voltage is automatically turned back on if ENPE is set.

## FRZ - Freeze Mode Control

$0=$ Disable program/erase voltage while FREEZE is asserted
1 = Allow ENPE bit to turn on the program/erase voltage while FREEZE is asserted
BOOT - Boot Control
0 = Flash EEPROM module responds to bootstrap addresses after reset
1 = Flash EEPROM module does not respond to bootstrap addresses after reset
On reset, BOOT takes on the value stored in its associated shadow bit. If $\mathrm{BOOT}=0$ and $\mathrm{STOP}=0$, the module responds to program space accesses to IMB addresses $\$ 000000$ to $\$ 000006$ following reset, and the contents of FEExBS[3:0] are used as bootstrap vectors. After address \$000006 is read, the module responds normally to control block or array addresses only.

LOCK — Lock Registers
$0=$ Write-locking disabled
1 = Write-locked registers protected
If the reset state of LOCK is zero, it can be set once after reset to allow protection of the registers after initialization. Once the LOCK bit is set by software, it cannot be cleared again until after a reset.

## ASPC[1:0] — Flash EEPROM Array Space

ASPC[1:0] assigns the array to supervisor or user space, and to program or data space. The state of ASPC[1:0] out of reset is determined by the value stored in the associated shadow bits. Since the CPU16 runs only in supervisor mode, ASPC1 must remain set to one for array accesses to take place. The field can be written only when LOCK $=0$ and $S T O P=1$. Refer to Table 66.

Table 66 Array Space Encoding

| ASPC[1:0] | Type of Access |
| :---: | :---: |
| 10 | Supervisor program and data space |
| 11 | Supervisor program space |

WAIT[1:0] — Wait States
The state of WAIT[1:0] out of reset is determined by the value stored in the associated shadow bits. WAIT[1:0] specifies the number of wait states inserted during accesses to the flash EEPROM module. A wait state has the duration of one system clock cycle. WAIT[1:0] affects both control block and array accesses, and can be written only if LOCK $=0$ and STOP $=1$. Refer to Table 67.

Table 67 Wait State Encoding

| WAIT[1:0] | Wait States | Clocks Per Transfer |
| :---: | :---: | :---: |
| 00 | 0 | 3 |
| 01 | 1 | 4 |
| 10 | 2 | 5 |
| 11 | -1 | 2 |

The value of WAIT[1:0] is compatible with the lower two bits of the $\overline{\text { DSACK }}$ field in the SCIM chip-select option registers. An encoding of $\% 11$ in WAIT[1:0] corresponds to an encoding for fast termination.

FEE1TST, FEE2TST — Flash EEPROM Test Registers
\$YFF802, \$YFF822
These registers are used for factory test only.

FEE1BAH, FEE2BAH - Flash EEPROM Base Address High Registers
\$YFF804, \$YFF824


FEE1BAL - Flash EEPROM Base Address Low Register
\$YFF806

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { ADDR } \\ 15 \end{gathered}$ | $\begin{array}{\|c} \hline \text { ADDR } \\ 14 \end{array}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| SB | SB | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

FEE2BAL — Flash EEPROM Base Address Low Register \$YFF826

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| SB | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

The base address high registers (FEE1BAH, FEE2BAH) contain the 8 high-order bits of the array base address; the base address low registers (FEE1BAL, FEE2BAL) contain the active low-order bits of the array base address. During reset, both FEExBAH and FEExBAL take on default values programmed into associated shadow registers. After reset, if LOCK $=0$ and STOP $=1$, software can write to FEExBAH and FEExBAL to relocate the array.

FEE1CTL, FEE2CTL - Flash EEPROM Control Register
\$YFF808, \$YFF828

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | VFPE | ERAS | LAT | ENPE |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

The flash EEPROM control registers (FEE1CTL, FEE2CTL) control programming and erasure of the arrays. FEExCTL is accessible in supervisor mode only.

VFPE - Verify Program/Erase
$0=$ Normal read cycles
1 = Invoke program verify circuit
The VFPE bit invokes a special program-verify circuit. During programming sequences (ERAS = 0), VFPE is used in conjunction with the LAT bit to determine when programming of a location is complete. If VFPE and LAT are both set, a bit-wise exclusive-OR of the latched data with the data in the location being programmed occurs when any valid FLASH location is read. If the location is completely programmed, a value of zero is read. Any other value indicates that the location is not fully programmed. When VFPE is cleared, normal reads of valid FLASH locations occur. The value of VFPE cannot be changed while ENPE $=1$.

## ERAS - Erase Control

$0=$ Flash EEPROM configured for programming
1 = Flash EEPROM configured for erasure
The ERAS bit configures the array for either programming or erasure. Setting ERAS causes all locations in the array and all control bits in the control block to be configured for erasure at the same time. When the LAT bit is set, ERAS also determines whether a read returns the data in the addressed location (ERAS $=1$ ) or the address itself (ERAS $=0$ ). ERAS cannot be changed while ENPE $=1$.

LAT - Latch Control
0 = Programming latches disabled
1 = Programming latches enabled
The LAT bit configures the EEPROM array for normal reads or for programming. When LAT is cleared, the FLASH module address and data buses are connected to the IMB address and data buses and the module is configured for normal reads. When LAT is set, module address and data buses are connected to parallel internal latches and the array is configured for programming or erasing.
Once LAT is set, the next write to a valid FLASH module address causes the programming circuitry to latch both address and data. Unless control register shadow bits are to be programmed, the write must be to an array address. The value of LAT cannot be changed while ENPE $=1$.

ENPE - Enable Programming/Erase
$0=$ Disable program/erase voltage
1 = Apply program/erase voltage to flash EEPROM
Setting the ENPE bit applies the program/erase voltage to the array. ENPE can be set only after LAT has been set and a write to the data and address latches has occurred. ENPE remains cleared if these conditions are not met. While ENPE is set, the LAT, VFPE, and ERAS bits cannot be changed, and attempts to read an array location are ignored.

FEE1BS[3:0] — Flash EEPROM Bootstrap Words
\$YFF810-\$YFF816
FEE2BS[3:0] — Flash EEPROM Bootstrap Words \$YFF830-\$YFF836
The flash EEPROM bootstrap words (FEE1BS[3:0], FEE2BS[3:0]) can be used as system bootstrap vectors. When BOOT $=1$ in FEExMCR during reset, the flash module responds to program space accesses of IMB addresses $\$ 000000$ to $\$ 000006$ after reset. When BOOT $=0$, the flash module responds only to normal array and register accesses. FEExBS[3:0] can be read at any time, but it can only be changed by programming the appropriate locations. Table 68 shows bootstrap word addresses in program space.

Table 68 Bootstrap Words

| Bootstrap Word | Corresponding <br> Boot Address | Corresponding <br> Vector Content |
| :---: | :---: | :---: |
| FEE1BS0, FEE2BS0 | $\$ 000000$ | Initial ZK, SK, and PC |
| FEE1BS1, FEE2BS1 | $\$ 000002$ | Initial PC |
| FEE1BS2, FEE2BS2 | $\$ 000004$ | Initial SP |
| FEE1BS3, FEE2BS3 | $\$ 000006$ | Initial IZ |

### 9.6 Flash EEPROM Operation

The following paragraphs describe the operation of the flash EEPROM module during reset, system boot, normal operation, and while it is being programmed or erased.

### 9.6.1 Reset Operation

Reset initializes all registers to certain default values. Some of these reset values are programmable by the user and are contained in flash EEPROM shadow registers. If the state of the STOP shadow bit is zero, and bus pin DATA14 is pulled high during reset, the STOP bit in the FEExMCR is cleared during reset. The array responds normally to the bootstrap address range and the flash EEPROM array base address. If the STOP shadow bit is one, or the module's associated data bus pin is pulled low during reset, the STOP bit in the FEExMCR is set. The flash EEPROM array is disabled until the STOP bit is cleared by software. It will not respond to the bootstrap address range, or the flash EEPROM array base address in FEExBAH and FEExBAL, allowing an external device to respond to the flash EEPROM array's address space or bootstrap information. Since the erased state of the shadow bits is one, erased flash EEPROM modules (which include the shadow registers in the control blocks) come out of reset in STOP mode.

### 9.6.2 Bootstrap Operation

After reset, the CPU begins bootstrap operation by fetching initial values for its internal registers from special bootstrap word addresses $\$ 000000$ through $\$ 000006$. If BOOT $=0$ and STOP $=0$ in FEExMCR, the flash EEPROM module is configured to recognize these addresses after a reset and provide this information from the FEExBS[3:0] bootstrap registers in the flash EEPROM control block. The information in these registers is programmed by the user.

### 9.6.3 Normal Operation

The flash EEPROM module allows a byte or aligned-word read in one bus cycle. Long-word reads require two bus cycles.

The module checks function codes to verify access privileges. All control block addresses must be in supervisor data space. Array accesses are defined by the state of ASPC[1:0] in FEExMCR. Access time is governed by the WAIT[1:0] field in FEExMCR.

Accesses to any address in the address block defined by FEExBAH and FEExBAL which does not fall within the array are ignored, allowing external devices to adjoin flash EEPROM arrays which do not entirely fill the entire address space specified by FEExBAH and FEExBAL.

### 9.6.4 Program/Erase Operation

An erased flash bit has a logic state of one. A bit must be programmed to change its state from one to zero. Erasing a bit returns it to a logic state of one. Programming and erasing the flash module requires a series of control register writes and a write to an array address. The same procedure is used to program control registers that contain flash shadow bits. Programming is restricted to a single byte or aligned word at a time. The entire array and the shadow register bits are erased at the same time.

When multiple flash modules share a single $\mathrm{V}_{\text {FPE }}$ pin, do not program or erase more than one flash module at a time. Normal accesses to modules that are not being programmed are not affected by programming or erasure of another flash module.

The following paragraphs give step-by-step procedures for programming and erasure of flash EEPROM arrays. Refer to 11 Electrical Characteristics for information on programming and erasing specifications for the flash EEPROM module.

### 9.6.4.1 Programming

The following steps are used to program a flash EEPROM array. Figure 22 is a flowchart of the programming operation. Refer to Figures 45 and 46 in 11 Electrical Characteristics for $\mathrm{V}_{\text {FPE }}$ to $\mathrm{V}_{\mathrm{DD}}$ relationships during programming.

1. Increase voltage applied to the $\mathrm{V}_{\text {FPE }}$ pin to program/erase/verify level.
2. Clear the ERAS bit and set the LAT bit in FEExCTL. This enables the programming address and data latches.
3. Write data to the address to be programmed. This latches the address to be programmed and the programming data.
4. Set the ENPE bit in FEExCTL. This starts the program pulse.
5. Delay the proper amount of time for one programming pulse to take place. Delay is specified by parameter $\mathrm{pw}_{\mathrm{pp}}$.
6. Clear the ENPE bit in FEExCTL. This stops the program pulse.
7. Delay while high voltage to array is turned off. Delay is specified by parameter $\mathrm{t}_{\mathrm{pr}}$.
8. Read the address to verify that it has been programmed.
9. If the location is not programmed, repeat steps 4 through 7 until the location is programmed, or until the specified maximum number of program pulses has been reached. Maximum number of pulses is specified by parameter $\mathrm{n}_{\mathrm{pp}}$.
10. If the location is programmed, repeat the same number of pulses as required to program the location. This provides $100 \%$ program margin.
11. Read the address to verify that it remains programmed.
12. Clear the LAT bit in FEExCTL. This disables the programming address and data latches.
13. If more locations are to be programmed, repeat steps 2 through 10.
14. Reduce voltage applied to the $\mathrm{V}_{\text {FPE }}$ pin to normal read level.

### 9.6.4.2 Erasure

The following steps are used to erase a flash EEPROM array. Figure 23 is a flowchart of the erasure operation. Refer to Figures 45 and 46 in 11 Electrical Characteristics for $\mathrm{V}_{\text {FPE }}$ to $\mathrm{V}_{\mathrm{DD}}$ relationships during erasure.

1. Increase voltage applied to the $\mathrm{V}_{\text {FPE }}$ pin to program/erase/verify level.
2. Set the ERAS bit and the LAT bit in FEExCTL. This configures the module for erasure.
3. Perform a write to any valid address in the control block or array. The data written does not matter.
4. Set the ENPE bit in FEExCTL. This applies the erase voltage to the array.
5. Delay the proper amount of time for one erase pulse. Delay is specified by parameter $t_{\text {epk }}$.
6. Clear the ENPE bit in FEExCTL. This turns off erase voltage to the array.
7. Delay while high voltage to array is turned off. Delay is specified by parameter $t_{e r}$.
8. Read the entire array and control block to ensure all locations are erased.
9. If all locations are not erased, calculate a new value for $\mathrm{t}_{\mathrm{epk}}\left(\mathrm{t}_{\mathrm{ei}} \times\right.$ pulse number) and repeat steps 3 through 10 until all locations erase, or the maximum number of pulses has been applied.
10. If all locations are erased, calculate the erase margin $\left(e_{m}\right)$ and repeat steps 3 through 10 for the single margin pulse.
11. Clear the LAT and ERAS bits in FEExCTL. This allows normal access to the flash.
12. Reduce voltage applied to the $\mathrm{V}_{\text {FPE }}$ pin to normal read level.


Figure 22 Programming Flow


Figure 23 Erasure Flow

## 10 Block-Erasable Flash EEPROM

The 2 Kbyte block-erasable flash EEPROM module (BEFLASH) serves as nonvolatile, fast-access ROM-emulation memory. The module can be used for program code that must either execute at high speed or is frequently executed, such as operating system kernels and standard subroutines, or it can be used for static data that is read frequently. The module can also be configured to provide bootstrap vectors for system reset.

### 10.1 Overview

The BEFLASH module consists of a control register block that occupies a fixed position in MCU address space and a 2 Kbyte flash EEPROM array that can be mapped to any 2 Kbyte boundary in MCU address space. The array can be configured to reside in both program and data space, or in program space alone.

The flash EEPROM array can be read as either bytes, words, or long-words. The module responds to back-to-back IMB accesses, providing two bus cycle (four system clocks) access for aligned long words. The module can also be programmed to insert up to three wait states per access, to accommodate migration from slower external development memory without re-timing the system.

Both the array and the individual control bits are programmable and erasable under software control. Program/erase voltage must be supplied via the external $\mathrm{V}_{\text {FPE2K }}$ pin. Data is programmed in byte or word aligned fashion. The module supports both block and bulk erase modes, and has a minimum program/erase life of 100 cycles. Hardware interlocks protect stored data from corruption if the program/erase voltage to the BEFLASH EEPROM array is enabled accidently. The BEFLASH array is enabled/disabled by a combination of DATA15 and the STOP shadow bit after reset.

Table 69 shows the BEFLASH address map.

Table 69 BEFLASH Address Map

| Address | $\mathbf{1 5}$ |
| :---: | :---: |
| \$YFF7A0 $^{1}$ | $\mathbf{8} \mathbf{7}$ |
| \$YFF7A2 | BEFLASH MODULE CONFIGURATION REGISTER (BFEMCR) |
| \$YFF7A4 | BEFLASH BASE ADDRESS HIGH REGISTER (BFEBAH) |
| \$YFF7A6 | BEFLASH BASE ADDRESS LOW REGISTER (BFEBAL) |
| \$YFF7A8 | BEFLASH CONTROL REGISTER (BFECTL) |
| \$YFF7AA | RESERVED |
| \$YFF7AC | RESERVED |
| \$YFF7AE | RESERVED |
| \$YFF7B0 | BEFLASH BOOTSTRAP WORD 0 (BFEBS0) |
| \$YFF7B2 | BEFLASH BOOTSTRAP WORD 1 (BFEBS1) |
| \$YFF7B4 | BEFLASH BOOTSTRAP WORD 2 (BFEBS2) |
| \$YFF7B6 | BEFLASH BOOTSTRAP WORD 3 (BFEBS3) |
| \$YFF7B8 | RESERVED |
| \$YFF7BA | RESERVED |
| \$YFF7BC | RESERVED |
| \$YFF7BE | RESERVED |

1. $Y=M 111$, where $M$ is the logic state of the module mapping (MM) bit in the SCIMCR.

### 10.2 BEFLASH Control Block

The BEFLASH module control block contains five registers: the BEFLASH module configuration register (BFEMCR), the BEFLASH test register (BFETST), the BEFLASH array base address registers (BFEBAH and BFEBAL), and the BEFLASH control register (BFECTL). Four additional words in the control block can contain bootstrap information when the BEFLASH is used as bootstrap memory.

Each register in the control block has an associated shadow register that is physically located in a spare BEFLASH row. During reset, fields within the registers are loaded with default information from the shadow registers. Shadow registers are programmed or erased in the same manner as locations in the BEFLASH array, using the address of the corresponding control registers. When a shadow register is programmed, the data is not written to the corresponding control register. The new data is not copied into the control register until the next reset. The contents of shadow registers are erased whenever the BEFLASH array is erased.

Configuration information is specified and programmed independently of the BEFLASH array. After reset, registers in the control block that contain writable bits can be modified. Writes to these registers do not affect the associated shadow register. Certain registers are writable only when the LOCK bit in BFEMCR is disabled or when the STOP bit in BFEMCR is set. These restrictions are noted in the individual register descriptions.

### 10.3 BEFLASH Array

The base address registers specify the starting address of the BEFLASH array. A default base address can be programmed into the base address shadow registers. The array base address must be on a 2 Kbyte boundary. Because the states of ADDR[23:20] follow the state of ADDR19, addresses in the range $\$ 080000$ to $\$$ F7FFFF cannot be accessed by the CPU16. If the BEFLASH array is mapped to these addresses, the system must be reset before the array can be accessed.

Avoid using a base address value that causes the array to overlap control registers. If a portion of the array overlaps the EEPROM register block, the registers remain accessible, but accesses to that portion of the array are ignored. If the array overlaps the control block of another module, however, those registers may become inaccessible. If the BEFLASH array overlaps another memory array (RAM or flash EEPROM), proper access to one or both arrays may not be possible.

### 10.4 BEFLASH Registers

In the following register diagrams, the reset value SB indicates that a bit assumes the value of its associated shadow bit during reset.


This register can be written only when the control block is not write-locked (when LOCK = 0). All active bits take values from the associated shadow register during reset.

STOP - Stop Mode Control
$0=$ Normal operation
1 = Low-power stop operation
STOP can be set either by pulling data bus pin DATA15 low during reset or by the corresponding shadow bit. The EEPROM array is inaccessible during low-power stop. The array can be re-enabled by
clearing STOP. If STOP is set during programming or erasing, the program/erase voltage is automatically turned off. However, the enable program/erase bit (ENPE) remains set. If STOP is cleared, program/erase voltage is automatically turned back on unless ENPE is cleared.

FRZ - Freeze Mode Control
0 = Disable program/erase voltage while FREEZE is asserted
1 = Allow ENPE bit to turn on the program/erase voltage while FREEZE signal is asserted
BOOT - Boot Control
$0=$ BEFLASH responds to bootstrap vector addresses after reset
$1=$ BEFLASH does not respond to bootstrap vector addresses after reset
On reset, BOOT takes on the value stored in its associated shadow bit. If $\mathrm{BOOT}=0$ and $\mathrm{STOP}=0$, the module responds to program space accesses of IMB addresses $\$ 000000$ to $\$ 000006$ following reset, and the contents of BFEBS[3:0] are used as bootstrap vectors. After address $\$ 000006$ is read, the module responds normally to control block or array addresses only.

LOCK — Lock Registers
$0=$ Write-locking disabled
1 = Write-locked registers protected
If the reset state of the LOCK is zero, it can be set once to protect the registers after initialization. When set, LOCK cannot be cleared until reset occurs.

ASPC[1:0] - BEFLASH Array Space
The CPU16 operates only in supervisory mode, and as a result, ASPC1 must remain set to one for array accesses to take place. The field can be written only if LOCK $=0$ and STOP $=1$. During reset, AS$\mathrm{PC}[1: 0]$ takes on the default value programmed into the associated shadow register. Refer to Table 70.

Table 70 Array Space Encoding

| ASPC[1:0] | Type of Access |
| :---: | :---: |
| 10 | Supervisor program and data space |
| 11 | Supervisor program space |

BFETST — BEFLASH Test Register
\$YFF7A2
This register is used for factory test purposes only.

| BFEB | - |  | Ba |  |  |  |  |  |  |  |  |  |  |  | F7A4 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  |  | NOT |  |  |  |  | ${ }_{23}^{\text {ADDR }}$ | $\begin{array}{\|c\|} \hline \text { ADDR } \\ 22 \end{array}$ | $\begin{array}{\|c} \hline \text { ADDR } \\ 21 \end{array}$ | $\begin{array}{\|l\|} \hline \text { ADDR } \\ 20 \end{array}$ | $\begin{gathered} \mathrm{ADDR} \\ 19 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 18 \end{gathered}$ | $\underset{17}{ }$ | $\begin{gathered} \mathrm{ADDR} \\ 16 \end{gathered}$ |
| RESET |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  | SB | SB | SB | SB | SB | SB | SB | SB |

BFEBAL — BEFLASH Base Address Low Register \$YFF7A6

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \hline \text { ADDR } \\ 15 \end{gathered}$ | $\begin{gathered} \hline \text { ADDR } \\ 14 \end{gathered}$ | $\begin{gathered} \text { ADDR } \\ 13 \end{gathered}$ | $\begin{array}{\|c} \hline \text { ADDR } \\ 12 \end{array}$ | $\begin{array}{\|c\|} \hline \text { ADDR } \\ 11 \end{array}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| SB | SB | SB | SB | SB | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

BFEBAH and BFEBAL contain the 13 high-order bits of the BEFLASH array base address. During reset, BFEBAH and BFEBAL take on the default values programmed into the associated shadow registers. After reset, if LOCK $=0$ and STOP $=1$, software can write to BFEBAH and BFEBAL to relocate the BEFLASH array. Because the states of ADDR[23:20] follow the state of ADDR19, addresses in the range $\$ 080000$ to $\$$ F7FFFF cannot be accessed by the CPU16. If the BEFLASH array is mapped to these addresses, the system must be reset before the array can be accessed.

| BFECTL - BEFLASH Control Register |  |  |  |  |  |  |  |  |  |  |  |  |  | \$YFF7A8 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | VFPE | ERAS | LAT | ENPE |
| RESET: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

BFECTL contains the bits needed to control programming and erasing the BEFLASH.
VFPE - Verify Program/Erase
$0=$ Normal read cycles
1 = Invoke program-verify circuit
This bit invokes a special program-verify circuit. During programming sequences (ERAS = 0), VFPE is used in conjunction with the LAT bit to determine when programming of a location is complete. If VFPE and LAT are both set, a bit-wise exclusive-OR of the latched data with the data in the location being programmed occurs when any valid BEFLASH location is read. If the location is completely programmed, a value of zero is read. Any other value indicates that the location is not fully programmed. When VFPE is cleared, normal reads of valid BEFLASH locations occur.

ERAS - Erase Control
$0=$ BEFLASH configured for programming
$1=$ BEFLASH configured for erasure

The ERAS bit in BFECTL configures the BEFLASH array for programming or erasure. Setting ERAS causes all locations in the array and all BEFLASH shadow bits in the control block to be configured for erasure. Table 71 shows the address ranges that must be written to during an erase operation in order to erase specific blocks of the BEFLASH array.

Table 71 BEFLASH Erase Operation Address Ranges

| Block | Addresses Affected | Address Bits Used to Specify Block for Erasure |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | ADDR[23:11] | ADDR[10:6] | ADDR5 | ADDR4 | ADDR3 | ADDR2 | ADDR1 | ADDR0 |
| 0 | \$0000 - \$007F | BFEBAH/ BFEBAL ${ }^{1}$ | $x^{2}$ | 1 | 0 | 0 | 0 | 0 | $x^{2}$ |
| 1 | \$0080-\$0100 |  |  | 1 | 0 | 0 | 0 | 1 |  |
| 2 | \$0100-\$017F |  |  | 1 | 0 | 0 | 1 | 0 |  |
| 3 | \$0180-\$01FF |  |  | 1 | 0 | 0 | 1 | 1 |  |
| 4 | \$0200-\$02FF |  |  | 1 | 0 | 1 | 0 | 0 |  |
| 5 | \$0300-\$03FF |  |  | 1 | 0 | 1 | 0 | 1 |  |
| 6 | \$0400-\$05FF |  |  | 1 | 0 | 1 | 1 | 0 |  |
| 7 | \$0600-\$07FF |  |  | 1 | 0 | 1 | 1 | 1 |  |
|  | Reserved |  |  | 1 | 1 | X | X | X |  |
| Entire Array ${ }^{3}$ | \$0600-\$07FF |  |  | 0 | X | X | X | X |  |

1. The block erasable flash base address high and low registers (BFEBAH and BFEBAL) specify ADDR[23:11] of the block to be erased.
2. These address bits are "don't cares" when specifying the block to be erased.
3. Erasing the entire array also erases the BEFLASH control register shadow bits.

When the LAT bit is set, ERAS also determines whether a read returns the value of the addressed location (ERAS $=1$ ) or the location being programmed (ERAS $=0$ ).

The value of ERAS cannot be changed if the program/erase voltage is turned on (ENPE =1).
LAT — Latch Control
$0=$ Programming latches disabled
1 = Programming latches enabled
When LAT is cleared, the BEFLASH address and data buses are connected to the IMB address and data buses. The BEFLASH is configured for normal reads. When LAT is set, the BEFLASH address and data buses are connected to parallel internal latches. The BEFLASH array is configured for programming or erasing.

Once LAT is set, the next write to a valid BEFLASH address causes the programming circuitry to latch both address and data. Unless control register shadow bits are to be programmed, the write must be to an array address.

The value of LAT cannot be changed when program/erase voltage is turned on (ENPE =1).
ENPE - Enable Program/Erase
$0=$ Disable program/erase voltage
1 = Apply program/erase voltage
ENPE can be set only after LAT has been set, and a write to the data and address latches has occurred. ENPE remains cleared if these conditions are not met. While ENPE is set, the LAT, VFPE, and ERAS bits cannot be changed, and attempts to read a BEFLASH array location in BEFLASH are ignored.

## BFEBS[3:0] — BEFLASH Bootstrap Words

\$YFF7B0 - \$YFF7B6
15
RESET:
PROGRAMMED VALUE
The BEFLASH bootstrap words (BFEBS[3:0]) can be used as system bootstrap vectors. When BOOT $=0$ in BFEMCR during reset, the BEFLASH responds to program space accesses of IMB addresses $\$ 000000$ to $\$ 000006$ after reset. When BOOT $=1$, the BEFLASH responds only to normal array and register accesses. BFEBS[3:0] can be read at any time, but the values in the words can only be changed by programming the appropriate locations.

### 10.5 BEFLASH Operation

The following paragraphs describe the operation of the BEFLASH during reset, system boot, normal operation, and while it is being programmed or erased.

### 10.5.1 Reset Operation

Reset initializes all BEFLASH control registers. Some bits have fixed default values, and some take values that are programmed into the associated BEFLASH shadow registers.

If the state of the STOP shadow bit is zero, and data bus pin DATA15 is pulled high during reset, the STOP bit in BFEMCR is cleared during reset, and the module responds to accesses in the range specified by BFEBAH and BFEBAL. When the BOOT bit is cleared, the module also responds to bootstrap vector accesses.

If the state of the STOP shadow bit is one, or data bus pin DATA15 is pulled low during reset, the STOP bit in BFEMCR is set during reset and the BEFLASH array is disabled. The module does not respond to array or bootstrap vector accesses until the STOP bit is cleared. This allows an external device to respond to accesses to the BEFLASH array address space or to bootstrap accesses. The erased state of the shadow bits is one. An erased module comes out of reset in STOP mode.

### 10.5.2 Bootstrap Operation

After reset, the CPU16 begins bootstrap operation by fetching initial values for its internal registers from IMB addresses $\$ 000000$ through $\$ 000006$ in program space. These are the addresses of the bootstrap vectors in the exception vector table. If BOOT $=0$ and STOP $=0$ in BFEMCR during reset, the BEFLASH module is configured to respond to bootstrap vector accesses. Vector assignments are shown in Table 72.

Table 72 Bootstrap Vector Assignments

| EEPROM Bootstrap Word | IMB Vector Address | MCU Reset Vector Content |
| :---: | :---: | :---: |
| BFEBS0 | $\$ 000000$ | Initial ZK, SK, and PK |
| BFEBS1 | $\$ 000002$ | Initial PC |
| BFEBS2 | $\$ 000004$ | Initial SP |
| BFEBS3 | $\$ 000006$ | Initial IZ |

As soon as address $\$ 000006$ has been read, BEFLASH operation returns to normal, and the module no longer responds to bootstrap vector accesses.

### 10.5.3 Normal Operation

The BEFLASH module allows a byte or aligned-word read in one bus cycle. Long-word reads require two bus cycles.

The module checks function codes to verify address space access type. Array accesses are defined by the state of ASPC[1:0] in BFEMCR.

### 10.5.4 Program/Erase Operation

An unprogrammed flash bit has a logic state of one. A bit must be programmed to change its state from one to zero. Erasing a bit returns it to a logic state of one. Programming or erasing the BEFLASH array requires a series of control register writes and a write to an array address. The same procedure is used to program control registers that contain flash bits. Programming is restricted to a single byte or aligned word at a time. Erasure of BEFLASH array blocks and control shadow bits are dependent on the setting of ADDR[3:1] of the address written to during an erase operation. Refer to Table 71 for the address bit patterns corresponding to specific BEFLASH blocks.

## NOTE

In order to program the array, programming voltage must be applied to the $\mathrm{V}_{\text {FPE2K }}$ pin. $\mathrm{V}_{\text {FPE2K }} \geq\left(\mathrm{V}_{\mathrm{DD}}-0.3 \mathrm{~V}\right)$ must be applied at all times or damage to the BEFLASH module can occur.

Refer to 11 Electrical Characteristics for information on programming and erasing specifications for the BEFLASH module.

### 10.5.4.1 Programming Sequence

Use the following procedure to program the BEFLASH. Refer to Figures 45 and 46 in 11 Electrical Characteristics for $\mathrm{V}_{\text {FPE }}$ to $\mathrm{V}_{\mathrm{DD}}$ relationships during programming.

1. Turn on $\mathrm{V}_{\text {FPE2K }}$ (apply program/erase voltage to $\mathrm{V}_{\text {FPE2K }}$ pin).
2. Clear ERAS and set LAT and VFPE bits in BFECTL to set program mode, enable programming address and data latches, and invoke special verification read circuitry. Set initial value of $t_{\text {ppulse }}$ to $t_{\text {pmin }}$.
3. Write new data to the desired address. This causes the address and data of the location to be programmed to be latched in the programming latches.
4. Set ENPE to apply programming voltage.
5. Delay long enough for one programming pulse to occur ( $\mathrm{t}_{\text {ppulse }}$ ).
6. Clear ENPE to remove programming voltage.
7. Delay while high voltage is turning off ( $\mathrm{t}_{\text {vprog }}$ ).
8. Read the location just programmed. If the value read is all zeros, proceed to step 9. If not, calculate a new value for $t_{\text {ppulse }}$ and repeat steps 4 through 7 until either the location is verified or the total programming time ( $\mathrm{t}_{\text {progmax }}$ ) has been exceeded. If $\mathrm{t}_{\text {progmax }}$ has been exceeded, the location may be bad and should not be used.
9. If the location is programmed, calculate $t_{\text {pmargin }}$ and repeat steps 4 through 7 . If the location does not remain programmed, the location is bad.
10. Clear VFPE and LAT.
11. If there are more locations to program, repeat steps 2 through 10.
12. Turn off $\mathrm{V}_{\text {FPE2K }}$ (reduce voltage on $\mathrm{V}_{\text {FPE2K }}$ pin to $\mathrm{V}_{\mathrm{DD}}$ ).
13. Read the entire array to verify that all locations are correct. If any locations are incorrect, the array is bad.

### 10.5.4.2 Erasure Sequence

Use the following procedure to erase the BEFLASH. Refer to Figures 45 and 46 in 11 Electrical Characteristics for $\mathrm{V}_{\text {FPE }}$ to $\mathrm{V}_{\mathrm{DD}}$ relationships during erasure.

1. Turn on $\mathrm{V}_{\text {FPE2K }}$ (apply program/erase voltage to $\mathrm{V}_{\text {FPE2K }} \mathrm{pin}$ ).
2. Set initial value of $t_{\text {epulse }}$ to $t_{\text {emin }}$.
3. Set LAT, VFPE, and ERAS bits to configure the BEFLASH module for erasure.
4. Write to any valid address in the control block or array. This allows the erase voltage to be turned on. The data written and the address written to are of no consequence.
5. Set ENPE to apply programming voltage.
6. Delay long enough for one erase pulse to occur ( $\mathrm{t}_{\text {epulse }}$ ).
7. Clear ENPE to remove programming voltage.
8. Delay while high voltage is turning off ( t verase)
9. Clear LAT, ERAS, and VFPE to allow normal access to the BEFLASH.
10. Read the entire array and control block to ensure that the entire module is erased.
11. If all of the locations are not erased, calculate a new value for $t_{\text {epulse }}$ and repeat steps 3 through 10 until either the remaining locations are erased or the maximum erase time (terasemax) has expired.
12. If all locations are erased, calculate $t_{\text {emargin }}$ and repeat steps 3 through 10. If all locations do not remain erased, the BEFLASH module may be bad.
13. Turn off $\mathrm{V}_{\text {FPE2K }}$ (reduce voltage on $\mathrm{V}_{\text {FPE2K }}$ pin to $\mathrm{V}_{\mathrm{DD}}$ ).

## 11 Electrical Characteristics

This section contains electrical specification tables and reference timing diagrams.

Table 73 Maximum Ratings

| Num | Rating | Symbol | Value | Unit |
| :---: | :--- | :---: | :---: | :---: |
| 1 | Supply Voltage $^{1,2,3}$ | $\mathrm{~V}_{\mathrm{DD}}$ | -0.3 to +6.5 | V |
| 2 | Input Voltage $^{1,2,3,4,5}$ | $\mathrm{~V}_{\text {in }}$ | -0.3 to +6.5 | V |
| 3 | Instantaneous Maximum Current <br> Single pin limit (applies to all pins) |  |  |  |
| 4 | Operating Maximum Current <br> Digital Input Disruptive Current <br> $3,5,5,6,7$ <br> $\mathrm{~V}_{\text {SS }}-0.3 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{DD}}+0.3$ | $\mathrm{I}_{\mathrm{D}}$ | 25 | mA |
| 5 | $\mathrm{I}_{\mathrm{ID}}$ | -500 to +500 | $\mu \mathrm{~A}$ |  |
| 6 | Operating Temperature Range <br> C Suffix | $\mathrm{T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$ <br> -40 to +85 | ${ }^{\circ} \mathrm{C}$ |
| 7 | Storage Temperature Range | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

1. Permanent damage can occur if maximum ratings are exceeded. Exposure to voltages or currents in excess of recommended values affects device reliability. Device modules may not operate normally while being exposed to electrical extremes.
2. Although sections of the device contain circuitry to protect against damage from high static voltages or electrical fields, take normal precautions to avoid exposure to voltages higher than maximum-rated voltages.
3. This parameter is periodically sampled rather than $100 \%$ tested.
4. Input must be current limited to the value specified. To determine the value of the required current-limiting resistor, calculate resistance values for positive and negative clamp voltages, then use the larger of the two values.
5. All functional non-supply pins are internally clamped to $\mathrm{V}_{S S}$ for transitions below $\mathrm{V}_{\mathrm{SS}}$. All functional pins except EXTAL and XFC are internally clamped to $\mathrm{V}_{\mathrm{DD}}$ for transitions below $\mathrm{V}_{\mathrm{DD}}$.
6. Power supply must maintain regulation within operating $\mathrm{V}_{\mathrm{DD}}$ range during instantaneous and operating maximum current conditions.
7. Total input current for all digital input-only and all digital input/output pins must not exceed 10 mA . Exceeding this limit can cause disruption of normal operation.
8. $\mathrm{V}_{\text {FPE }}$ must not be raised to programming level while $\mathrm{V}_{\mathrm{DD}}$ is below specified minimum value. $\mathrm{V}_{\text {FPE }}$ must not be reduced below minimum specified value while $\mathrm{V}_{\mathrm{DD}}$ is applied.
9. Flash EEPROM modules can be damaged by power-on and power-off $\mathrm{V}_{\text {FPE }}$ transients. Maximum power-on overshoot tolerance is 13.5 V for periods of less than 30 ns .

Table 74 Typical Ratings

| Num | Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| 1 | Supply Voltage | $V_{\text {DD }}$ | 5.0 | V |
| 2 | Operating Temperature | $\mathrm{T}_{\mathrm{A}}$ | 25 | ${ }^{\circ} \mathrm{C}$ |
| 3 | $\mathrm{V}_{\mathrm{DD}}$ Supply Current RUN LPSTOP, VCO Off LPSTOP, External clock, max $\mathrm{f}_{\text {sys }}$ | ${ }_{\text {dD }}$ | $\begin{gathered} 116 \\ 500 \\ 3 \end{gathered}$ | $\underset{\mu A}{m A}$ |
| 4 | Clock Synthesizer Operating Voltage | $\mathrm{V}_{\text {DDSYN }}$ | 5.0 | V |
| 5 | $\mathrm{V}_{\text {DDSYN }}$ Supply Current VCO on, maximum $f_{\text {sys }}$ External Clock, maximum $f_{\text {sys }}$ LPSTOP, VCO off $V_{D D}$ powered down | Iddsyn | $\begin{aligned} & 1.0 \\ & 4.0 \\ & 125 \\ & 60 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mu \mathrm{~A} \\ & \mu \mathrm{~A} \end{aligned}$ |
| 6 | RAM Standby Voltage | $\mathrm{V}_{\text {SB }}$ | 3.0 | V |
| 7 | RAM Standby Current Normal RAM operation Standby operation | $\mathrm{I}_{\text {SB }}$ | $\begin{aligned} & 7.0 \\ & 40.0 \end{aligned}$ | ${ }_{\mu \mathrm{A}}^{\mu \mathrm{A}}$ |
| 8 | Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | 600 | mW |

Table 75 Thermal Characteristics

| Num | Characteristic | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: | :---: |
| 1 | Thermal Resistance <br> Plastic 120-Pin Surface Mount | $\Theta_{\mathrm{JA}}$ | 61.2 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |

The average chip-junction temperature ( $\mathrm{T}_{\mathrm{J}}$ ) in C can be obtained from:

$$
\begin{equation*}
T_{J}=T_{A}+\left(P_{D} \times \Theta_{J A}\right) \tag{1}
\end{equation*}
$$

where:

| $\mathrm{T}_{\text {A }}$ | $=$ Ambient Temperature, ${ }^{\circ} \mathrm{C}$ |
| :---: | :---: |
| $\Theta_{\mathrm{JA}}$ | = Package Thermal Resistance, Junction-to-Ambient, ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| $\mathrm{P}_{\mathrm{D}}$ | $=\mathrm{P}_{\text {INT }}+\mathrm{P}_{\text {I/O }}$ |
| $\mathrm{P}_{\text {INT }}$ | $=I_{D D} \times V_{D D}$, Watts - Chip Internal Power |
| $\mathrm{P}_{1 / \mathrm{O}}$ | = Power Dissipation on Input and Output Pins - User Determined |

For most applications $\mathrm{P}_{/ / \mathrm{O}}<\mathrm{P}_{\text {INT }}$ and can be neglected. An approximate relationship between $P_{D}$ and $T_{J}$ (if $P_{1 / O}$ is neglected) is:

$$
\begin{equation*}
P_{D}=K \div\left(T_{J}+273^{\circ} C\right) \tag{2}
\end{equation*}
$$

Solving equations 1 and 2 for $K$ gives:

$$
\begin{equation*}
K=P_{D}+\left(T_{A}+273^{\circ} \mathrm{C}\right)+\Theta_{J A} \times P_{D^{2}} \tag{3}
\end{equation*}
$$

where K is a constant pertaining to the particular part. K can be determined from equation (3) by measuring $P_{D}$ (at equilibrium) for a known $T_{A}$. Using this value of $K$, the values of $P_{D}$ and $T_{J}$ can be obtained by solving equations (1) and (2) iteratively for any value of $T_{A}$.

Table 76 Clock Control Timing
$\left(\mathrm{V}_{\mathrm{DD}}\right.$ and $\mathrm{V}_{\mathrm{DDSYN}}=5.0 \mathrm{Vdc} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\left.\mathrm{T}_{\mathrm{H}}\right)$

| Num | Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | PLL Reference Frequency Range ${ }^{1}$ | $\mathrm{f}_{\text {ref }}$ | 3.2 | 4.2 | MHz |
| 2 | System Frequency ${ }^{2}$ On-Chip PLL System Frequency Range External Clock Operation | $\mathrm{f}_{\text {sys }}$ | $\begin{gathered} \mathrm{dc} \\ 4\left(\mathrm{f}_{\mathrm{reff}}\right) / 128 \\ \mathrm{dc} \end{gathered}$ | $\begin{aligned} & 16.78 \\ & 16.78 \\ & 16.78 \end{aligned}$ | MHz |
| 3 | PLL Lock Time ${ }^{\text {1, 3, 4, 5, } 6}$ | $\mathrm{t}_{1 \mathrm{pl\mid}}$ | - | 20 | ms |
| 4 | VCO Frequency ${ }^{7}$ | $\mathrm{f}_{\mathrm{VcO}}$ | - | 2 ( $\mathrm{f}_{\text {sys }} \mathrm{max}$ ) | MHz |
| 5 | Limp Mode Clock Frequency SYNCR $X$ bit $=0$ SYNCR $X$ bit $=1$ | $\mathrm{f}_{\text {limp }}$ | - | $\begin{aligned} & \mathrm{f}_{\mathrm{sys}} \max / 2 \\ & \mathrm{f}_{\mathrm{sys}} \max \end{aligned}$ | MHz |
| 6 | CLKOUT Jitter ${ }^{1,4,5, ~ 6, ~} 8$ <br> Short term ( $5 \mu \mathrm{~s}$ interval) Long term ( $500 \mu \mathrm{~s}$ interval) | $J_{\text {clk }}$ | $\begin{gathered} -0.5 \\ -0.05 \end{gathered}$ | $\begin{gathered} 0.5 \\ 0.05 \end{gathered}$ | \% |

1. Tested with a 4.194 MHz reference.
2. All internal registers retain data at 0 Hz .
3. Assumes that stable $\mathrm{V}_{\text {DDSYN }}$ is applied, and that the crystal oscillator is stable. Lock time is measured from the time $\mathrm{V}_{\mathrm{DD}}$ and $\mathrm{V}_{\text {DDSYN }}$ are valid until $\overline{\mathrm{RESET}}$ is released. This specification also applies to the period required for PLL lock after changing the $W$ and $Y$ frequency control bits in the synthesizer control register (SYNCR ) while the PLL is running, and to the period required for the clock to lock after LPSTOP.
4. This parameter is periodically sampled rather than $100 \%$ tested.
5. Assumes that a low-leakage external filter network is used to condition clock synthesizer input voltage. Total external resistance from the XFC pin due to external leakage must be greater than $15 \mathrm{M} \Omega$ to guarantee this specification. Filter network geometry can vary depending upon operating environment.
6. Proper layout procedures must be followed to achieve specifications.
7. Internal VCO frequency ( $f_{V C O}$ ) is determined by SYNCR $W$ and $Y$ bit values.

The SYNCR $X$ bit controls a divide-by-two circuit that is not in the synthesizer feedback loop.
When $X=0$, the divider is enabled, and $f_{\text {sys }}=f_{V C O} \div 4$.
When $X=1$, the divider is disabled, and $f_{\text {sys }}=f_{\mathrm{VcO}} \div 2$.
$X$ must equal one when operating at maximum specified $f_{\text {sys }}$.
8. Jitter is the average deviation from the programmed frequency measured over the specified interval at maximum $f_{\text {sys }}$. Measurements are made with the device powered by filtered supplies and clocked by a stable external clock signal. Noise injected into the PLL circuitry via $\mathrm{V}_{\text {DDSYN }}$ and $\mathrm{V}_{S S}$ and variation in crystal oscillator frequency increase the $J_{\mathrm{Clk}}$ percentage for a given interval. When clock jitter is a critical constraint on control system operation, this parameter should be measured during functional testing of the final system.

Table 77 DC Characteristics
$\left(\mathrm{V}_{\mathrm{DD}}\right.$ and $\mathrm{V}_{\mathrm{DDSYN}}=5.0 \mathrm{Vdc} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\left.\mathrm{T}_{\mathrm{H}}\right)$

| Num | Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 0.7 ( $\mathrm{V}_{\mathrm{DD}}$ ) | $\mathrm{V}_{\mathrm{DD}}+0.3$ | V |
| 2 | Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{S S}-0.3$ | $0.2\left(\mathrm{~V}_{\mathrm{DD}}\right)$ | V |
| 3 | Input Hysteresis ${ }^{1,2}$ | $\mathrm{V}_{\mathrm{HYS}}$ | 0.5 | - | V |
| 4 | Input Leakage Current ${ }^{3}$ $\mathrm{~V}_{\text {in }}=\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\text {SS }} \quad$ All input-only pins except ADC pins | $\mathrm{I}_{\mathrm{N}}$ | -2.5 | 2.5 | $\mu \mathrm{A}$ |
| 5 | High Impedance $(\text { Off-State })^{3}$  <br> Leakage Current  <br> $V_{\text {in }}=V_{D D}$ or $V_{S S}$ All input/output and output pins | $\mathrm{I}_{\mathrm{OZ}}$ | -2.5 | 2.5 | $\mu \mathrm{A}$ |
| 6 | $\begin{aligned} & \text { CMOS Output High Voltage }{ }^{3,4} \text { Group 1, 2, } 4 \text { input/output and all output pins } \\ & \mathrm{I}_{\mathrm{OH}}=-10.0 \mu \mathrm{~A} \end{aligned}$ | $\mathrm{V}_{\mathrm{OH}}$ | $V_{D D}-0.2$ | - | V |
| 7 | $\begin{aligned} & \text { CMOS Output Low Voltage }{ }^{3} \quad \text { Group 1, 2, } 4 \text { input/output and all output pins } \\ & \mathrm{I}_{\mathrm{OL}}=10.0 \mu \mathrm{~A} \end{aligned}$ | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.2 | V |
| 8 | Output High Voltage ${ }^{3,4} \quad$ Group 1, 2, 4 input/output and all output pins $\mathrm{I}_{\mathrm{OH}}=-0.8 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{OH}}$ | $V_{D D}-0.8$ | - | V |
| 9 | ```Output Low Voltage }\mp@subsup{}{}{3 IOL = 1.6 mA Group 1 I/O Pins, CLKOUT, FREEZE/QUOT, IPIPE0 I IOL}=12\textrm{mA}\quad\mathrm{ Group 3``` | $\mathrm{V}_{\mathrm{OL}}$ | - | $\begin{aligned} & 0.4 \\ & 0.4 \\ & 0.4 \end{aligned}$ | V |
| 10 | Data Bus Mode Select ${ }^{5}$  <br> Pull-up Current  <br> $V_{\text {in }}=V_{I L}$ DATA[15:0] <br> $\mathrm{V}_{\text {in }}=\mathrm{V}_{\mathrm{IH}}$ DATA[15:0] | $\mathrm{I}_{\text {MSP }}$ | $\overline{-15}$ | -120 | $\mu \mathrm{A}$ |
| 11 | $\mathrm{V}_{\mathrm{DD}}$ Supply Current ${ }^{6}$ <br> Run ${ }^{7}$ <br> LPSTOP, 4.194 MHz crystal, VCO Off (STSIM = 0) <br> LPSTOP, External clock input frequency $=$ maximum $f_{\text {sys }}$ | $\mathrm{I}_{\mathrm{DD}}$ | - | $\begin{gathered} 150 \\ 2 \\ 10 \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |
| 12 | Clock Synthesizer Operating Voltage | $V_{\text {DDSYN }}$ | 4.5 | 5.5 | V |
| 13 | $\mathrm{V}_{\text {DDSYN }}$ Supply Current ${ }^{6}$ <br> 4.194 MHz crystal, VCO on, maximum $f_{\text {sys }}$ <br> External Clock, maximum $f_{\text {sys }}$ <br> LPSTOP, 4.194 MHz crystal, VCO off (STSIM = 0) <br> 4.194 MHz crystal, $\mathrm{V}_{\mathrm{DD}}$ powered down | $\mathrm{I}_{\text {DDSYN }}$ | - | $\begin{aligned} & 2 \\ & 7 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |
| 14 | $\begin{aligned} & \text { RAM Standby Voltage }{ }^{8} \\ & \text { Specified } V_{D D} \text { applied } \\ & V_{D D}=V_{S S} \end{aligned}$ | $\mathrm{V}_{\mathrm{SB}}$ | $\begin{aligned} & 0.0 \\ & 3.0 \end{aligned}$ | $\begin{aligned} & 5.5 \\ & 5.5 \end{aligned}$ | V |
| 15 | RAM Standby Current ${ }^{6}$  <br> Normal RAM operation ${ }^{9}$ $\mathrm{~V}_{\mathrm{DD}}>\mathrm{V}_{\mathrm{SB}}-0.5 \mathrm{~V}$ <br> Transient condition $\mathrm{V}_{\mathrm{SB}}-0.5 \mathrm{~V} \geq \mathrm{V}_{\mathrm{DD}} \geq \mathrm{V}_{\mathrm{SS}}+0.5 \mathrm{~V}$ <br> Standby operation ${ }^{8}$ $\mathrm{~V}_{\mathrm{DD}}<\mathrm{V}_{\mathrm{SS}}+0.5 \mathrm{~V}$ | $I_{\text {SB }}$ | - | $\begin{gathered} 50 \\ 3 \\ 100 \end{gathered}$ | $\mu \mathrm{A}$ mA $\mu \mathrm{A}$ |
| 16 | Power Dissipation ${ }^{10}$ | $\mathrm{P}_{\mathrm{D}}$ | - | 865 | mW |
| 17 | Input Capacitance ${ }^{2,3}$ All input-only pins except ADC pins <br> All input/output pins  | $\mathrm{C}_{\text {IN }}$ | - | $\begin{aligned} & 10 \\ & 20 \end{aligned}$ | pF |

Table 77 DC Characteristics (Continued)

$$
\left(\mathrm{V}_{\mathrm{DD}} \text { and } \mathrm{V}_{\mathrm{DDSYN}}=5.0 \mathrm{Vdc} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{~T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}} \text { to } \mathrm{T}_{\mathrm{H}}\right)
$$

| Num | Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 18 | Load Capacitance ${ }^{3}$ Group 1 I/O Pins, CLKOUT, FREEZE/QUOT, IPIPE0 |  |  |  |  |
|  | Group 2 I/O Pins and BG/CSM | $C_{\mathrm{L}}$ | - | 90 |  |
|  | Group 3 I/O Pins |  |  | 100 | pF |
|  | Group 4 I/O Pins | - | 130 |  |  |
|  |  |  |  | 200 |  |

1. Applies to:

Port ADA[5:0] - AN[5:0]
Port E[7:4], 1 - SIZ[1:0], $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$
Port F[7:6], 0 - $\overline{\mathrm{RQ}[7: 6], ~ M O D C L K ~}$
Port GP[7:0] — IC4/OC5/OC1, IC[3:1], OC[4:1]/OC1
Port QS[7:0] — TXD, PCS[3:1], PCS0/SS, SCK, MOSI, MISO
BKPT/DSCLK, DSI/IPIPE1, PAI, PCLK, RESET, RXD, TSC
EXTAL (when PLL enabled)
2. This parameter is periodically sampled rather than $100 \%$ tested.
3. Input-Only Pins: EXTAL, TSC, BKPT/DSCLK, PAI, PCLK, RXD

Output-Only Pins: ADDR[2:0], $\overline{\mathrm{BG}} / \overline{\mathrm{CSM}}, \mathrm{CLKOUT}, \mathrm{FREEZE/QUOT}, \mathrm{DSO/IPIPE0}, \mathrm{PWMA}$,
Group 1: Port GP[7:0] - IC4/OC5/OC1, IC[3:1], OC[4:1]/OC1
DATA[15:0], DSI/IPIPE1
Group 2: Port C[3:0] — ADDR19/CS6, FC[2:0]/CS5/CS3
Port E[7:4], 1 - SIZ[1:0], $\overline{\text { AS }}, \overline{\mathrm{DS}}, \overline{\mathrm{DSACK}}$
Port F[7:6], 0 — IRQ[7:6], MODCLK
Port QS[7:3] — TXD, PCS[3:1], PCS0/SS
ADDR23/CS10/ECLK, ADDR[18:0], R/W, $\overline{\mathrm{BERR}}, \overline{\mathrm{BR}} / \overline{\mathrm{CSO}}, \overline{\mathrm{BG}} / \overline{\mathrm{CSM}}, \overline{\mathrm{BGACK}} / \overline{\mathrm{CSE}}$
4. Does not apply to RESET because it is an open drain pin. Does not apply to Port QS[7:0] (TXD, PCS[3:1], PCS0/SS, SCK, MOSI, MISO) in wired-OR mode.
5. Use of an active pulldown device is recommended.
6. Total operating current is the sum of the appropriate $I_{D D}, I_{D D S Y N}$, and $I_{S B}$ values, plus $I_{D D A}$. $I_{D D}$ values include supply currents for device modules powered by $\mathrm{V}_{\text {DDE }}$ and $\mathrm{V}_{\text {DII }}$ pins.
7. Current measured at maximum system clock frequency, all modules active.
8. The SRAM module will not switch into standby mode as long as $V_{S B}$ does not exceed $V_{D D}$ by more than 0.5 volts. The SRAM array cannot be accessed while the module is in standby mode.
9. When $\mathrm{V}_{\mathrm{SB}}$ is more than 0.3 V greater than $\mathrm{V}_{\mathrm{DD}}$, current flows between the $\mathrm{V}_{\mathrm{STBY}}$ and $\mathrm{V}_{\mathrm{DD}}$ pins, which causes standby current to increase toward the maximum transient condition specification. System noise on the $V_{D D}$ and $V_{S T B Y}$ pin can contribute to this condition.
10. Power dissipation is measured at maximum system clock frequency, all modules active. Power dissipation can be calculated using the following expression:

$$
\mathrm{P}_{\mathrm{D}}=\text { Maximum } \mathrm{V}_{\mathrm{DD}}\left(\mathrm{I}_{\mathrm{DD}}+\mathrm{I}_{\mathrm{DDSY}}+\mathrm{I}_{\mathrm{SB}}\right)+\text { Maximum } \mathrm{V}_{\mathrm{DDA}}\left(\mathrm{I}_{\mathrm{DDA}}\right)
$$

$I_{D D}$ includes supply currents for all device modules powered by $V_{D D E}$ and $V_{D D I}$ pins.

Table 78 AC Timing
$\left(\mathrm{V}_{\mathrm{DD}} \text { and } \mathrm{V}_{\mathrm{DDSYN}}=5.0 \mathrm{Vdc} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}} \text { to } \mathrm{T}_{\mathrm{H}}\right)^{1}$

| Num | Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| F1 | Frequency of Operation ${ }^{2}$ | f | 4 f (ref)/128 | 16.78 | MHz |
| 1 | Clock Period | $\mathrm{t}_{\mathrm{cyc}}$ | 59.6 | - | ns |
| 1A | ECLK Period | $t_{\text {Ecyc }}$ | 476 | - | ns |
| 1B | External Clock Input Period ${ }^{3}$ | $t_{\text {Xcyc }}$ | 59.6 | - | ns |
| 2, 3 | Clock Pulse Width | $\mathrm{t}_{\mathrm{CW}}$ | 28 | - | ns |
| 2A, 3A | ECLK Pulse Width | $t_{\text {ECW }}$ | 236 | - | ns |
| 2B, 3B | External Clock Input High/Low Time ${ }^{3}$ | ${ }^{\text {t }}$ CCHL | 29.8 | - | ns |
| 4, 5 | CLKOUT Rise and Fall Time | $\mathrm{t}_{\mathrm{Crf}}$ | - | 5 | ns |
| 4A, 5A | Rise and Fall Time (All Outputs except CLKOUT) | $\mathrm{t}_{\mathrm{ff}}$ | - | 8 | ns |
| 4B, 5B | External Clock Input Rise and Fall Time ${ }^{4}$ | ${ }^{\text {txCrf }}$ | - | 5 | ns |
| 6 | Clock High to ADDR, FC, SIZE Valid | $\mathrm{t}_{\text {CHAV }}$ | 0 | 29 | ns |
| 7 | Clock High to ADDR, Data, FC, SIZE, High Impedance | $\mathrm{t}_{\text {CHAZx }}$ | 0 | 59 | ns |
| 8 | Clock High to ADDR, FC, SIZE, Invalid | $\mathrm{t}_{\text {CHAZn }}$ | 0 | - | ns |
| 9 | Clock Low to $\overline{\text { AS, }} \overline{\mathrm{DS}}, \overline{\mathrm{CS}}$ Asserted | ${ }^{\text {t CLSA }}$ | 2 | 25 | ns |
| 9A | $\overline{\mathrm{AS}}$ to $\overline{\mathrm{DS}}$ or $\overline{\mathrm{CS}}$ Asserted (Read) ${ }^{5}$ | tstsa | -15 | 15 | ns |
| 11 | ADDR, FC, SIZE Valid to $\overline{\text { AS, }} \overline{\mathrm{CS}}$, (and $\overline{\mathrm{DS}}$ Read) Asserted | $\mathrm{t}_{\text {AVSA }}$ | 15 | - | ns |
| 12 | Clock Low to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}, \overline{\mathrm{CS}}$ Negated | $\mathrm{t}_{\mathrm{CLSN}}$ | 2 | 29 | ns |
| 13 | $\overline{\text { AS, }} \overline{\mathrm{DS}}, \overline{\mathrm{CS}}$ Negated to ADDR, FC SIZE Invalid (Address Hold) | $\mathrm{t}_{\text {SNAI }}$ | 15 | - | ns |
| 14 | $\overline{\mathrm{AS}}, \overline{\mathrm{CS}}$ (and $\overline{\mathrm{DS}}$ Read) Width Asserted | tswa | 100 | - | ns |
| 14A | $\overline{\overline{D S}}$, $\overline{\mathrm{CS}}$ Width Asserted (Write) | tswaw | 45 | - | ns |
| 14B | $\overline{\mathrm{AS}}, \overline{\mathrm{CS}}$ (and $\overline{\mathrm{DS}}$ Read) Width Asserted (Fast Cycle) | tswDw | 40 | - | ns |
| 15 | $\overline{\text { AS, }} \overline{\mathrm{DS}}, \overline{\mathrm{CS}}$ Width Negated ${ }^{6}$ | $\mathrm{t}_{\mathrm{SN}}$ | 40 | - | ns |
| 16 | Clock High to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$, R/ $\overline{\mathrm{W}}$ High Impedance | $\mathrm{t}_{\mathrm{CHSZ}}$ | - | 59 | ns |
| 17 | $\overline{\text { AS, }} \overline{\mathrm{DS}}$, $\overline{\mathrm{CS}}$ Negated to R/W High | $t_{\text {SNRN }}$ | 15 | - | ns |
| 18 | Clock High to R/W High | $\mathrm{t}_{\text {CHRH }}$ | 0 | 29 | ns |
| 20 | Clock High to R/W Low | $\mathrm{t}_{\mathrm{CHRL}}$ | 0 | 29 | ns |
| 21 | R/W High to $\overline{\mathrm{AS}}, \overline{\mathrm{CS}}$ Asserted | $t_{\text {RAAA }}$ | 15 | - | ns |
| 22 | R/W Low to DS, $\overline{\mathrm{CS}}$ Asserted (Write) | $t_{\text {RASA }}$ | 70 | - | ns |
| 23 | Clock High to Data Out Valid | $\mathrm{t}_{\text {CHDO }}$ | - | 29 | ns |
| 24 | Data Out Valid to Negating Edge of $\overline{\text { AS, }} \overline{\mathrm{CS}}$ (Fast Write Cycle) | $\mathrm{t}_{\text {DVASN }}$ | 15 | - | ns |
| 25 | $\overline{\overline{D S}}, \overline{\mathrm{CS}}$ Negated to Data Out Invalid (Data Out Hold) | ${ }^{\text {tsNDOI }}$ | 15 | - | ns |
| 26 | Data Out Valid to $\overline{\mathrm{DS}}$, $\overline{\mathrm{CS}}$ Asserted (Write) | $\mathrm{t}_{\text {DVSA }}$ | 15 | - | ns |
| 27 | Data In Valid to Clock Low (Data Setup) | $\mathrm{t}_{\text {DICL }}$ | 5 | - | ns |
| 27A | Late BERR Asserted to Clock Low (Setup Time) | $\mathrm{t}_{\text {BELCL }}$ | 20 | - | ns |
| 28 | $\overline{\text { AS }}$, $\overline{\text { DS }}$ Negated to $\overline{\text { DSACK1, }}$, $\overline{B E R R}$, Negated | $t_{\text {SNDN }}$ | 0 | 80 | ns |
| 29 | $\overline{\text { DS, }} \overline{\mathrm{CS}}$ Negated to Data In Invalid (Data In Hold) ${ }^{7}$ | ${ }^{\text {tSNDI }}$ | 0 | - | ns |
| 29A | $\overline{\mathrm{DS}}, \overline{\mathrm{CS}}$ Negated to Data In High Impedance ${ }^{7,8}$ | $\mathrm{t}_{\text {SHDI }}$ | - | 55 | ns |
| 30 | CLKOUT Low to Data In Invalid (Fast Cycle Hold) ${ }^{7}$ | ${ }^{\text {t CLDI }}$ | 15 | - | ns |
| 30A | CLKOUT Low to Data In High Impedance ${ }^{7}$ | ${ }^{\text {t CLDH }}$ | - | 90 | ns |

Table 78 AC Timing (Continued)
$\left(\mathrm{V}_{\mathrm{DD}} \text { and } \mathrm{V}_{\mathrm{DDSYN}}=5.0 \mathrm{Vdc} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}} \text { to } \mathrm{T}_{\mathrm{H}}\right)^{1}$

| Num | Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 31 | DSACK1 Asserted to Data In Valid ${ }^{9}$ | $\mathrm{t}_{\text {DADI }}$ | - | 50 | ns |
| 33 | Clock Low to BG Asserted/Negated | tcLBAN | - | 29 | ns |
| 35 | $\overline{\mathrm{BR}}$ Asserted to $\overline{\mathrm{BG}}$ Asserted ${ }^{10}$ | $t_{\text {BRAGA }}$ | 1 | - | $\mathrm{t}_{\mathrm{cyc}}$ |
| 37 | BGACK Asserted to BG Negated | $\mathrm{t}_{\text {GAGN }}$ | 1 | 2 | $\mathrm{t}_{\mathrm{cyc}}$ |
| 39 | $\overline{\mathrm{BG}}$ Width Negated | $\mathrm{t}_{\mathrm{GH}}$ | 2 | - | $\mathrm{t}_{\mathrm{cyc}}$ |
| 39A | $\overline{\text { BG Width Asserted }}$ | $\mathrm{t}_{\mathrm{GA}}$ | 1 | - | $\mathrm{t}_{\mathrm{cyc}}$ |
| 46 | R/̄W Width Asserted (Write or Read) | $t_{\text {RWA }}$ | 150 | - | ns |
| 46A | R/W Width Asserted (Fast Write or Read Cycle) | $\mathrm{t}_{\text {RWAS }}$ | 90 | - | ns |
| 47A | Asynchronous Input Setup Time $\overline{\mathrm{BR}}, \overline{\mathrm{BGACK}}, \overline{\mathrm{DSACK}}, \overline{\mathrm{BERR}}$ | ${ }^{\text {AIST }}$ | 5 | - | ns |
| 47B | Asynchronous Input Hold Time | $\mathrm{t}_{\text {AlHT }}$ | 15 | - | ns |
| 48 |  | $\mathrm{t}_{\text {DABA }}$ | - | 30 | ns |
| 53 | Data Out Hold from Clock High | $\mathrm{t}_{\text {DOCH }}$ | 0 | - | ns |
| 54 | Clock High to Data Out High Impedance | $\mathrm{t}_{\text {CHDH }}$ | - | 28 | ns |
| 55 | R/W Asserted to Data Bus Impedance Change | $\mathrm{t}_{\text {RADC }}$ | 40 | - | ns |
| 70 | Clock Low to Data Bus Driven (Show Cycle) | $t_{\text {SCLDD }}$ | 0 | 29 | ns |
| 71 | Data Setup Time to Clock Low (Show Cycle) | tsclds | 15 | - | ns |
| 72 | Data Hold from Clock Low (Show Cycle) | tscloh | 10 | - | ns |
| 73 | BKPT Input Setup Time | $\mathrm{t}_{\text {BKST }}$ | 15 | - | ns |
| 74 | BKPT Input Hold Time | $\mathrm{t}_{\text {BKHT }}$ | 10 | - | ns |
| 75 | Mode Select Setup Time (DATA[15:0], MODCLK, $\overline{\mathrm{BKPT}}$ ) | $\mathrm{t}_{\text {MSS }}$ | 20 | - | $\mathrm{t}_{\mathrm{cyc}}$ |
| 76 | Mode Select Hold Time (DATA[15:0], MODCLK, BKPT) | $\mathrm{t}_{\text {MSH }}$ | 0 | - | ns |
| 77 | RESET Assertion Time ${ }^{12}$ | $\mathrm{t}_{\text {RSTA }}$ | 4 | - | $\mathrm{t}_{\text {cyc }}$ |
| 78 | $\overline{\text { RESET Rise Time }}{ }^{13}$ | $\mathrm{t}_{\text {RSTR }}$ | - | 10 | $\mathrm{t}_{\mathrm{cyc}}$ |
| 100 | CLKOUT High to Phase 1 Asserted ${ }^{14}$ | $\mathrm{t}_{\text {CHP1A }}$ | 3 | 40 | ns |
| 101 | CLKOUT High to Phase 2 Asserted ${ }^{14}$ | $\mathrm{t}_{\text {CHP2A }}$ | 3 | 40 | ns |
| 102 | Phase 1 Valid to $\overline{\mathrm{AS}}$ or $\overline{\mathrm{DS}}$ Asserted ${ }^{14}$ | $t_{\text {P1VSA }}$ | 10 | - | ns |
| 103 | Phase 2 Valid to $\overline{\mathrm{AS}}$ or $\overline{\mathrm{DS}}$ Asserted ${ }^{14}$ | tP2VSN | 10 | - | ns |
| 104 | $\overline{\mathrm{AS}}$ or $\overline{\mathrm{DS}}$ Valid to Phase 1 Negated ${ }^{14}$ | $t_{\text {SAP1N }}$ | 10 | - | ns |
| 105 | $\overline{\text { AS }}$ or DS Negated to Phase 2 Negated ${ }^{14}$ | $t_{\text {SNP2N }}$ | 10 | - | ns |

1. All $A C$ timing is shown with respect to $20 \% V_{D D}$ and $70 \% V_{D D}$ levels unless otherwise noted.
2. The base configuration of the MC68HC916X1 requires a 4.194 MHz crystal reference.
3. When an external clock is used, minimum high and low times are based on a $50 \%$ duty cycle. The minimum allowable $t_{\text {Xcyc }}$ period is reduced when the duty cycle of the external clock varies. The relationship between external clock input duty cycle and minimum $\mathrm{t}_{\mathrm{Xcyc}}$ is expressed:

Minimum $t_{\text {Xcyc }}$ period $=$ minimum $t_{\text {XCHL }} /(50 \%$ - external clock input duty cycle tolerance $)$.
4. Parameters for an external clock signal applied while the internal PLL is disabled (MODCLK pin held low during reset). Does not pertain to an external VCO reference applied while the PLL is enabled (MODCLK pin held high during reset). When the PLL is enabled, the clock synthesizer detects successive transitions of the reference signal. If transitions occur within the correct clock period, rise/fall times and duty cycle are not critical.
5. Specification 9A is the worst-case skew between $\overline{\mathrm{AS}}$ and $\overline{\mathrm{DS}}$ or $\overline{\mathrm{CS}}$. The amount of skew depends on the relative loading of these signals. When loads are kept within specified limits, skew will not cause $\overline{\mathrm{AS}}$ and $\overline{\mathrm{DS}}$ to fall outside the limits shown in specification 9.
6. If multiple chip selects are used, $\overline{\mathrm{CS}}$ width negated (specification 15) applies to the time from the negation of a heavily loaded chip select to the assertion of a lightly loaded chip select. The $\overline{\mathrm{CS}}$ width negated specification between multiple chip selects does not apply to chip selects being used for synchronous ECLK cycles.
7. Hold times are specified with respect to $\overline{\mathrm{DS}}$ or $\overline{\mathrm{CS}}$ on asynchronous reads and with respect to CLKOUT on fast cycle reads. The user is free to use either hold time.
8. Maximum value is equal to $\left(\mathrm{t}_{\mathrm{cyc}} / 2\right)+25 \mathrm{~ns}$.
9. If the asynchronous setup time (specification 47A) requirements are satisfied, the DSACK1 low to data setup time (specification 31) and $\overline{\text { DSACK1 }}$ low to $\overline{B E R R}$ low setup time (specification 48) can be ignored. The data must only satisfy the data-in to clock low setup time (specification 27) for the following clock cycle. $\overline{B E R R}$ must satisfy only the late $\overline{B E R R}$ low to clock low setup time (specification 27A) for the following clock cycle.
10. To ensure coherency during every operand transfer, $\overline{B G}$ is not asserted in response to $\overline{B R}$ until after all cycles of the current operand transfer are complete.
11. In the absence of $\overline{\text { DSACK1 }}, \overline{B E R R}$ is an asynchronous input using the asynchronous setup time (specification 47A).
12. After external RESET negation is detected, a short transition period (approximately $2 \mathrm{t}_{\text {cyc }}$ ) elapses, then the SIM drives RESET low for $512 \mathrm{t}_{\mathrm{cyc}}$.
13. External logic must pull RESET high during this period in order for normal MCU operation to begin.
14. Eight pipeline states are multiplexed into IPIPE[1:0]. The multiplexed signals have two phases.
15. Address access time $=(2.5+W S) t_{\text {cyc }}-t_{\text {CHAV }}-t_{\text {DICL }}$

Chip select access time $=(2+W S) \mathrm{t}_{\mathrm{cyc}}-\mathrm{t}_{\text {CLSA }}-\mathrm{t}_{\text {DICL }}$
Where: WS = number of wait states. When fast termination is used ( 2 clock bus) WS = 1 .


NOTE: TIMING SHOWN WITH RESPECT TO 20\% AND 70\% V $\mathrm{V}_{\mathrm{DD}}$

Figure 24 CLKOUT Output Timing Diagram


NOTE: TIMING SHOWN WITH RESPECT TO 20\% AND 70\% V PULSE WIDTH SHOWN WITH RESPECT TO 50\% V $\mathrm{V}_{\mathrm{DD}}$

Figure 25 External Clock Input Timing Diagram


NOTE: TIMING SHOWN WITH RESPECT TO 20\% AND 70\% V ${ }_{D D}$

Figure 26 ECLK Output Timing Diagram


Figure 27 Read Cycle Timing Diagram


* ON THE MC68HC916X1, THE $\overline{H A L T}$ AND $\overline{\text { DSACKO }}$ PINS ARE NOT BONDED AND ARE INTERNALLY PULLED UP TO VDD.

Figure 28 Write Cycle Timing Diagram


16 FAST RD CYC TIM

Figure 29 Fast Termination Read Cycle Timing Diagram


Figure 30 Fast Termination Write Cycle Timing Diagram


* ON THE MC68HC916X1 THE DSACKO PIN IS NOT BONDED AND IS INTERNALLY PULLED UP TO V $\mathrm{V}_{\mathrm{DD}}$.

Figure 31 Bus Arbitration Timing Diagram - Active Bus Case


16 BUS ARB TIM IDLE
Figure 32 Bus Arbitration Timing Diagram - Idle Bus Case


NOTE:
SHOW CYCLES CAN STRETCH DURING CLOCK PHASE S42 WHEN BUS ACCESSES TAKE LONGER THAN TWO CYCLES DUE TO IMB MODULE WAIT-STATE INSERTION.

Figure 33 Show Cycle Timing Diagram


16 CHIP SEL TIM

Figure 34 Chip Select Timing Diagram


Figure 35 Reset and Mode Select Timing Diagram

Table 79 Background Debugging Mode Timing
$\left(\mathrm{V}_{\mathrm{DD}} \text { and } \mathrm{V}_{\mathrm{DDSYN}}=5.0 \mathrm{Vdc} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}} \text { to } \mathrm{T}_{\mathrm{H}}\right)^{1}$

| Num | Characteristic | Symbol | Min | Max | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| B0 | DSI Input Setup Time | $\mathrm{t}_{\mathrm{DSISU}}$ | 15 | - | ns |
| B1 | DSI Input Hold Time | $\mathrm{t}_{\mathrm{DSIH}}$ | 10 | - | ns |
| B2 | DSCLK Setup Time | $\mathrm{t}_{\mathrm{DSCSU}}$ | 15 | - | ns |
| B3 | DSCLK Hold Time | $\mathrm{t}_{\mathrm{DSCH}}$ | 10 | - | ns |
| B4 | DSO Delay Time | $\mathrm{t}_{\mathrm{DSOD}}$ | - | 25 | ns |
| B5 | DSCLK Cycle Time | $\mathrm{t}_{\mathrm{DScc}}$ | 2 | - | $\mathrm{t}_{\text {cyc }}$ |
| B6 | CLKOUT Low to FREEZE Asserted/Negated | $\mathrm{t}_{\text {FRZAN }}$ | - | 50 | ns |
| B7 | CLKOUT High to IPIPE1 High Impedance | $\mathrm{t}_{\mathrm{IFZ}}$ | - | 50 | ns |
| B8 | CLKOUT High to IPIPE1 Valid | $\mathrm{t}_{\mathrm{IF}}$ | - | 50 | ns |
| B9 | DSCLK Low Time | $\mathrm{t}_{\text {DSCLO }}$ | 1 | - | $\mathrm{t}_{\text {cyc }}$ |
| B10 | IPIPE1 High Impedance to FREEZE Asserted | $\mathrm{t}_{\text {IPFA }}$ | TBD | - | $\mathrm{t}_{\text {cyc }}$ |
| B11 | FREEZE Negated to IPIPE[1:0] Active | $\mathrm{t}_{\text {FRIP }}$ | TBD | - | $\mathrm{t}_{\mathrm{cyc}}$ |

1. All $A C$ timing is shown with respect to $20 \% V_{D D}$ and $70 \% V_{D D}$ levels unless otherwise noted.


Figure 36 Background Debugging Mode Timing Diagram Serial Communication


16 BDM FRZ TIM

Figure 37 Background Debugging Mode Timing Diagram Freeze Assertion

Table 80 ECLK Bus Timing
$\left(\mathrm{V}_{\mathrm{DD}} \text { and } \mathrm{V}_{\mathrm{DDSYN}}=5.0 \mathrm{Vdc} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}} \text { to } \mathrm{T}_{\mathrm{H}}\right)^{1}$

| Num | Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| E1 | ECLK Low to Address Valid ${ }^{2}$ | $t_{\text {EAD }}$ | - | 60 | ns |
| E2 | ECLK Low to Address Hold | $\mathrm{t}_{\text {EAH }}$ | 15 | - | ns |
| E3 | ECLK Low to $\overline{\mathrm{CS}}$ Valid ( $\overline{\mathrm{CS}}$ Delay) | $\mathrm{t}_{\text {ECSD }}$ | - | 150 | ns |
| E4 | ECLK Low to $\overline{\mathrm{CS}}$ Hold | $\mathrm{t}_{\text {ECSH }}$ | 15 | - | ns |
| E5 | $\overline{\text { CS }}$ Negated Width | $\mathrm{t}_{\text {ECSN }}$ | 30 | - | ns |
| E6 | Read Data Setup Time | $\mathrm{t}_{\text {EDSR }}$ | 30 | - | ns |
| E7 | Read Data Hold Time | $\mathrm{t}_{\text {EDHR }}$ | 5 | - | ns |
| E8 | ECLK Low to Data High Impedance | $\mathrm{t}_{\text {EDHZ }}$ | - | 60 | ns |
| E9 | $\overline{\text { CS Negated to Data Hold (Read) }}$ | $\mathrm{t}_{\text {ECDH }}$ | 0 | - | ns |
| E10 | $\overline{\text { CS Negated to Data High Impedance }}$ | $\mathrm{t}_{\text {ECDZ }}$ | - | 1 | $\mathrm{t}_{\mathrm{cyc}}$ |
| E11 | ECLK Low to Data Valid (Write) | $t_{\text {EDDW }}$ | - | 2 | $\mathrm{t}_{\mathrm{cyc}}$ |
| E12 | ECLK Low to Data Hold (Write) | $\mathrm{t}_{\text {EDHW }}$ | 15 | - | ns |
| E13 | $\overline{\mathrm{CS}}$ Negated to Data Hold (Write) | $\mathrm{t}_{\text {ECHW }}$ | 0 | - | ns |
| E14 | Address Access Time (Read) ${ }^{3}$ | $\mathrm{t}_{\text {EACC }}$ | 386 | - | ns |
| E15 | Chip-Select Access Time (Read) ${ }^{4}$ | teacs | 296 | - | ns |
| E16 | Address Setup Time | teas | - | 1/2 | $\mathrm{t}_{\mathrm{cyc}}$ |

1. All $A C$ timing is shown with respect to $20 \% V_{D D}$ and $70 \% V_{D D}$ levels unless otherwise noted.
2. When previous bus cycle is not an ECLK cycle, the address may be valid before ECLK goes low.
3. Address access time $=\mathrm{t}_{\mathrm{Ecyc}}-\mathrm{t}_{\mathrm{EAD}}-\mathrm{t}_{\mathrm{EDSR}}$.
4. Chip-select access time $=t_{\text {Ecyc }}-t_{E C S D}-t_{\text {EDSR }}$.


Figure 38 ECLK Timing Diagram

Table 81 QSPI Timing
$\left(\mathrm{V}_{\mathrm{DD}} \text { and } \mathrm{V}_{\mathrm{DDSYN}}=5.0 \mathrm{Vdc} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}} \text { to } \mathrm{T}_{\mathrm{H}} 200 \mathrm{pF} \text { load on all QSPI pins }\right)^{1}$

| Num | Function | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | Operating Frequency Master Slave | $\mathrm{f}_{\mathrm{op}}$ | $\begin{aligned} & \mathrm{DC} \\ & \mathrm{DC} \end{aligned}$ | $\begin{aligned} & 1 / 4 \\ & 1 / 4 \end{aligned}$ | System Clock Frequency System Clock Frequency |
| 1 | Cycle Time Master Slave | $\mathrm{t}_{\text {ccyc }}$ | 4 4 | 510 | $\begin{aligned} & \frac{t_{\mathrm{cyc}}}{\mathrm{t}_{\mathrm{cyc}}} \end{aligned}$ |
| 2 | Enable Lead Time Master Slave | $\mathrm{t}_{\text {lead }}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | 128 | $\begin{gathered} \mathrm{c}_{\mathrm{cyc}} \\ \mathrm{t}_{\mathrm{cyc}} \end{gathered}$ |
| 3 | $\begin{aligned} & \text { Enable Lag Time } \\ & \text { Master } \\ & \text { Slave } \end{aligned}$ | $\mathrm{t}_{\text {ag }}$ | $\overline{2}$ | $\stackrel{1 / 2}{-}$ | $\begin{gathered} \mathrm{SCK} \\ \mathrm{t}_{\mathrm{cyc}} \end{gathered}$ |
| 4 | Clock (SCK) High or Low Time Master Slave ${ }^{2}$ | $\mathrm{t}_{\text {sw }}$ | $\begin{aligned} & 2 \mathrm{t}_{\mathrm{cyc}}-60 \\ & 2 \mathrm{t}_{\mathrm{cyc}}-\mathrm{n} \end{aligned}$ | $255 \mathrm{t}_{\mathrm{cyc}}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| 5 | Sequential Transfer Delay Master Slave (Does Not Require Deselect) | $\mathrm{t}_{\text {dd }}$ | $\begin{aligned} & 17 \\ & 13 \end{aligned}$ | $8192$ | $\begin{gathered} \mathrm{c}_{\mathrm{cyc}} \\ \mathrm{t}_{\mathrm{cyc}} \end{gathered}$ |
| 6 | Data Setup Time (Inputs) Master Slave | $\mathrm{t}_{\text {su }}$ | $\begin{aligned} & 30 \\ & 20 \end{aligned}$ | - | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| 7 | Data Hold Time (Inputs) Master Slave | $t_{\text {hi }}$ | $\begin{gathered} 0 \\ 20 \end{gathered}$ | - | ns ns |
| 8 | Slave Access Time | $\mathrm{t}_{\mathrm{a}}$ | - | 1 | $\mathrm{t}_{\text {cyc }}$ |
| 9 | Slave MISO Disable Time | $\mathrm{t}_{\text {dis }}$ | - | 2 | $\mathrm{t}_{\text {cyc }}$ |
| 10 | $\begin{aligned} & \text { Data Valid (after SCK Edge) } \\ & \text { Master } \\ & \text { Slave } \end{aligned}$ | $\mathrm{t}_{\mathrm{v}}$ | - | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | ns ns |
| 11 | Data Hold Time (Outputs) Master Slave | $t_{\text {ho }}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 二 | ns ns |
| 12 | Rise Time Input Output | $\begin{array}{r} \mathrm{t}_{\mathrm{rir}} \\ \mathrm{t}_{\mathrm{ro}} \\ \hline \end{array}$ | 二 | $\begin{gathered} 2 \\ 30 \end{gathered}$ | $\begin{aligned} & \mu \mathrm{s} \\ & \mathrm{~ns} \end{aligned}$ |
| 13 | Fall Time Input ${ }^{3}$ Output | $\begin{aligned} & \mathrm{t}_{\mathrm{tif}} \\ & \mathrm{t}_{\mathrm{fo}} \end{aligned}$ | - | $\begin{gathered} 2 \\ 30 \end{gathered}$ | $\begin{aligned} & \mu \mathrm{s} \\ & \mathrm{~ns} \end{aligned}$ |

1. All $A C$ timing is shown with respect to $20 \% V_{D D}$ and $70 \% V_{D D}$ levels unless otherwise noted.
2. For high time, $\mathrm{n}=$ External SCK rise time; for low time, $\mathrm{n}=$ External SCK fall time.
3. Data can be recognized properly with longer transition times as long as MOSI/MISO signals from external sources are at valid $\mathrm{V}_{\mathrm{OH}} / \mathrm{V}_{\mathrm{OL}}$ prior to SCK transitioning between valid $\mathrm{V}_{\mathrm{OL}}$ and $\mathrm{V}_{\mathrm{OH}}$. Due to process variation, logic decision point voltages of the data and clock signals can differ, which can corrupt data if slower transition times are used.


Figure 39 QSPI Timing - Master, CPHA = 0


Figure 40 QSPI Timing - Master, CPHA = 1


Figure 41 QSPI Timing - Slave, CPHA = 0


Figure 42 QSPI Timing - Slave, CPHA = 1

Table 82 ADC Maximum Ratings

| Num | Parameter | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Analog Supply | $\mathrm{V}_{\text {DDA }}$ | -0.3 | 6.5 | V |
| 2 | Internal Digital Supply, with reference to $\mathrm{V}_{\text {SSI }}$ | $\mathrm{V}_{\text {DDI }}$ | -0.3 | 6.5 | V |
| 3 | Reference Supply, with reference to $\mathrm{V}_{\text {SSI }}$ | $\mathrm{V}_{\mathrm{RH}}, \mathrm{V}_{\mathrm{RL}}$ | -0.3 | 6.5 | V |
| 4 | $\mathrm{V}_{\text {SS }}$ Differential Voltage | $\mathrm{V}_{\text {SSI }}-\mathrm{V}_{\text {SSA }}$ | -0.1 | 0.1 | V |
| 5 | $\mathrm{V}_{\text {DD }}$ Differential Voltage | $\mathrm{V}_{\text {DDI }}-\mathrm{V}_{\text {DDA }}$ | -6.5 | 6.5 | V |
| 6 | $\mathrm{V}_{\text {REF }}$ Differential Voltage | $\mathrm{V}_{\mathrm{RH}}-\mathrm{V}_{\mathrm{RL}}$ | -6.5 | 6.5 | V |
| 7 | $\mathrm{V}_{\mathrm{RH}}$ to $\mathrm{V}_{\text {DDA }}$ Differential Voltage | $\mathrm{V}_{\mathrm{RH}}-\mathrm{V}_{\text {DDA }}$ | -6.5 | 6.5 | V |
| 8 | $\mathrm{V}_{\text {RL }}$ to $\mathrm{V}_{\text {SSA }}$ Differential Voltage | $\mathrm{V}_{\mathrm{RL}}-\mathrm{V}_{\text {SSA }}$ | -6.5 | 6.5 | V |
| 9 | $\begin{aligned} & \text { Disruptive Input Current }{ }^{1,2,3,4,5,6,7} \\ & V_{\text {NEGCLAMP }} \cong-0.3 \mathrm{~V} \\ & \mathrm{~V}_{\text {POSCLAMP }} \cong 8 \mathrm{~V} \end{aligned}$ | ${ }^{\text {INA }}$ | - 500 | 500 | $\mu \mathrm{A}$ |
| 10 | Positive Overvoltage Current Coupling Ratio ${ }^{1,5,6,8}$ | $\mathrm{K}_{\mathrm{P}}$ | 2000 | - | - |
| 11 | Negative Overvoltage Current Coupling Ratio ${ }^{\text {1, 5, 6, }} 8$ | $\mathrm{K}_{\mathrm{N}}$ | 500 | - | - |
| 12 | $\begin{aligned} & \text { Maximum Input Current }{ }^{3,4,6} \\ & \text { V }_{\text {NEGCLAMP }} \cong-0.3 \mathrm{~V} \\ & \mathrm{~V}_{\text {POSCLAMP }} \cong 8 \mathrm{~V} \end{aligned}$ | $\mathrm{l}_{\text {MA }}$ | -25 | 25 | mA |

1. Below disruptive current conditions, a stressed channel will store the maximum conversion value for analog inputs greater than $\mathrm{V}_{\mathrm{RH}}$ and the minimum conversion value for inputs less than $\mathrm{V}_{\mathrm{RL}}$. This assumes that $\mathrm{V}_{\mathrm{RH}} \leq \mathrm{V}_{\mathrm{DDA}}$ and $\mathrm{V}_{\mathrm{RL}} \geq \mathrm{V}_{\mathrm{SSA}}$ due to the presence of the sample amplifier. Other channels are not affected by non-disruptive conditions
2. Input signals with large slew rates or high frequency noise components cannot be converted accurately. These signals also interfere with conversion of other channels.
3. Exceeding limit may cause conversion error on stressed channels and on unstressed channels. Transitions within the limit do not affect device reliability or cause permanent damage.
4. Input must be current limited to the value specified. To determine the value of the required current-limiting resistor, calculate resistance values using positive and negative clamp values, then use the larger of the calculated values.
5. This parameter is periodically sampled rather than $100 \%$ tested.
6. Applies to single pin only.
7. The values of external system components can change the maximum input current value, and affect operation. A voltage drop may occur across the external source impedances of the adjacent pins, impacting conversions on these adjacent pins. The actual maximum may need to be determined by testing the complete design.
8. Current coupling is the ratio of the current induced from overvoltage (positive or negative, through an external series coupling resistor), divided by the current induced on adjacent pins. A voltage drop may occur across the external source impedances of the adjacent pins, impacting conversions on these adjacent pins.

Table 83 ADC DC Electrical Characteristics (Operating)
$\left(\mathrm{V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \operatorname{ADCLK}=2.1 \mathrm{MHz}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\right.$ to $\left.\mathrm{T}_{\mathrm{H}}\right)$

| Num | Parameter | Symbol | Min | Max | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| 1 | Analog Supply |  |  |  |  |
| 2 | Internal Digital Supply $^{1}$ | $\mathrm{~V}_{\mathrm{DDA}}$ | 4.5 | 5.5 | V |
| 3 | $\mathrm{~V}_{\text {SS }}$ Differential Voltage | $\mathrm{V}_{\mathrm{DDI}}$ | 4.5 | 5.5 | V |
| 4 | $\mathrm{~V}_{\mathrm{DD}}$ Differential Voltage | $\mathrm{V}_{\mathrm{SSI}}-\mathrm{V}_{\mathrm{SSA}}$ | -1.0 | 1.0 | mV |
| 5 | Reference Voltage Low $^{2,3}$ | $\mathrm{~V}_{\mathrm{DDI}}-\mathrm{V}_{\mathrm{DDA}}$ | -1.0 | 1.0 | V |
| 6 | Reference Voltage High $^{2,3}$ | $\mathrm{~V}_{\mathrm{RL}}$ | $\mathrm{V}_{\mathrm{SSA}}$ | $\mathrm{V}_{\mathrm{DDA}} / 2$ | V |
| 7 | $\mathrm{~V}_{\text {REF }}$ Differential Voltage ${ }^{3}$ | $\mathrm{~V}_{\mathrm{RH}}$ | $\mathrm{V}_{\mathrm{DDA}} / 2$ | $\mathrm{~V}_{\mathrm{DDA}}$ | V |
| 8 | Input Voltage $^{2}$ | $\mathrm{~V}_{\mathrm{RH}}-\mathrm{V}_{\mathrm{RL}}$ | 4.5 | 5.5 | V |
| 9 | Input High, Port ADA | $\mathrm{V}_{\text {INDC }}$ | $\mathrm{V}_{\mathrm{SSA}}$ | $\mathrm{V}_{\mathrm{DDA}}$ | V |
| 10 | Input Low, Port ADA | $\mathrm{V}_{\mathrm{IH}}$ | $0.7\left(\mathrm{~V}_{\mathrm{DDA}}\right)$ | $\mathrm{V}_{\mathrm{DDA}}+0.3$ | V |
| 11 | Analog Supply Current $^{\text {Normal Operation }^{4}}$ | $\mathrm{~V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{SSA}}-0.3$ | $0.2\left(\mathrm{~V}_{\mathrm{DDA}}\right)$ | V |
| 12 | Reference Supply Current | $\mathrm{I}_{\mathrm{DDA}}$ | - | 1.0 | mA |
| 13 | Input Current, Off Channel |  |  |  |  |

1. Refers to operation over full temperature and frequency range.
2. To obtain full-scale, full-range results, $\mathrm{V}_{\mathrm{SSA}} \leq \mathrm{V}_{\mathrm{RL}} \leq \mathrm{V}_{\text {INDC }} \leq \mathrm{V}_{\mathrm{RH}} \leq \mathrm{V}_{\mathrm{DDA}}$.
3. Accuracy tested and guaranteed at $\mathrm{V}_{\mathrm{RH}}-\mathrm{V}_{\mathrm{RL}} \leq 5.0 \mathrm{~V} \pm 10 \%$.
4. Current measured at maximum system clock frequency with ADC active.
5. Maximum leakage occurs at maximum operating temperature. Current decreases by approximately one-half for each $10^{\circ} \mathrm{C}$ decrease from maximum temperature.

Table 84 ADC AC Characteristics (Operating)

| Num | Parameter | Symbol | Min | Max | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| 1 | ADC Clock Frequency | $\mathrm{f}_{\text {ADCLK }}$ | 0.5 | 2.1 | MHz |
| 2 | 8-bit Conversion Time |  |  |  |  |
|  | $\mathrm{f}_{\text {ADCLK }}=1.0 \mathrm{MHz}$ |  |  |  | $\mu \mathrm{m}$ |
|  | $\mathrm{f}_{\text {ADCLK }}=2.1 \mathrm{MHz}$ | $\mathrm{t}_{\mathrm{CONV}}$ | 15.2 | - |  |
| 3 | 10-bit Conversion Time |  |  |  |  |
|  | $\mathrm{f}_{\text {ADCLK }}=1.0 \mathrm{MHz}$ |  |  |  |  |
|  | $\mathrm{f}_{\text {ADCLK }}=2.1 \mathrm{MHz}$ | $\mathrm{t}_{\mathrm{CONV}}$ | 17.1 | - | $\mu \mathrm{s}$ |
| 4 | Stop Recovery Time |  | 8.6 |  | $\mu \mathrm{~s}$ |

1. Conversion accuracy varies with $\mathrm{f}_{\text {ADCLK }}$ rate. Reduced conversion accuracy occurs at maximum.

Table 85 ADC Conversion Characteristics (Operating)
$\left(\mathrm{V}_{\mathrm{DD}}\right.$ and $\mathrm{V}_{\mathrm{DDA}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{S S}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$, $0.5 \mathrm{MHz} \leq \mathrm{f}_{\text {ADCLK }} \leq 1.0 \mathrm{MHz}$, 2 Clock Input Sample Time)

| Num | Parameter | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 8-bit Resolution ${ }^{1}$ | 1 Count | - | 20 | - | mV |
| 2 | 8-bit Differential Nonlinearity | DNL | -0.5 | - | -0.5 | Counts |
| 3 | 8-bit Integral Nonlinearity | INL | -1 | - | 1 | Counts |
| 4 | 8-bit Absolute Error ${ }^{2}$ | AE | -1 | - | 1 | Counts |
| 5 | 10-bit Resolution ${ }^{1}$ | 1 Count | - | 5 | - | mV |
| 6 | 10-bit Differential Nonlinearity ${ }^{3}$ | DNL | -0.5 | - | -0.5 | Counts |
| 7 | 10-bit Integral Nonlinearity ${ }^{3}$ | INL | -2.0 | - | 2.0 | Counts |
| 8 | 10-bit Absolute Error ${ }^{3,4}$ | AE | -2.5 | - | 2.5 | Counts |
| 9 | Source Impedance at Input ${ }^{5}$ | $\mathrm{R}_{S}$ | - | 20 | - | $\mathrm{k} \Omega$ |

1. At $\mathrm{V}_{\mathrm{RH}}-\mathrm{V}_{\mathrm{RL}}=5.12 \mathrm{~V}$, one 10 -bit count $=5 \mathrm{mV}$ and one 8 -bit count $=20 \mathrm{mV}$.
2. 8 -bit absolute error of 1 count ( 20 mV ) includes $1 / 2$ count ( 10 mV ) inherent quantization error and $1 / 2$ count ( 10 mV ) circuit (differential, integral, and offset) error.
3. Conversion accuracy varies with $f_{A D C L K}$ rate. Reduced conversion accuracy occurs at maximum $f_{A D C L K}$. Assumes that minimum sample time (2 ADC Clocks) is selected.
4. 10-bit absolute error of 2.5 counts ( 12.5 mV ) includes $1 / 2$ count $(2.5 \mathrm{mV})$ inherent quantization error and 2 counts ( 10 mV ) circuit (differential, integral, and offset) error.
5. Maximum source impedance is application-dependent. Error resulting from pin leakage depends on junction leakage into the pin and on leakage due to charge-sharing with internal capacitance.
Error from junction leakage is a function of external source impedance and input leakage current. Expected error in result value due to junction leakage is expressed in voltage $\left(\mathrm{V}_{\text {ERRJ }}\right)$ :

$$
\mathrm{V}_{\text {ERRJ }}=\mathrm{R}_{\mathrm{S}} \times \mathrm{I}_{\mathrm{OFF}}
$$

where $\mathrm{l}_{\text {OFF }}$ is a function of operating temperature, as shown in Table 83.
Charge-sharing leakage is a function of input source impedance, conversion rate, change in voltage between successive conversions, and the size of the decoupling capacitor used. Error levels are best determined empirically. In general, continuous conversion of the same channel may not be compatible with high source impedance.


A - +1/2 COUNT ( 10 mV ) INHERENT QUANTIZATION ERROR
B - CIRCUIT-CONTRIBUTED +10 mV ERROR
$\mathrm{C}-+20 \mathrm{mV}$ ABSOLUTE ERROR (ONE 8-BIT COUNT)
ADC 8-BIT ACCURACY
Figure 43 8-Bit ADC Conversion Accuracy


A - +. 5 COUNT ( 2.5 mV ) INHERENT QUANTIZATION ERROR
B - CIRCUIT-CONTRIBUTED +10 mV ERROR
C -+12.5 mV ABSOLUTE ERROR (2.5 10-BIT COUNTS)

Figure 44 10-Bit ADC Conversion Accuracy

Table 86 BEFLASH/Flash EEPROM Module Specifications

| Num | Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Program/Erase Supply Voltage ${ }^{1}$ Read Operation Program/Erase/Verify Operation | $V_{\text {FPE }}$ | $\begin{gathered} \mathrm{V}_{\mathrm{DD}}-0.5 \\ 11.4 \end{gathered}$ | $\begin{gathered} 5.5 \\ 12.6 \end{gathered}$ | V |
| 2 | Program/Erase Supply Current ${ }^{2}$ Read Operation Program/Erase/Verify Operation Verify (ENPE = 0) <br> Program Byte $(E N P E=1)$ Program Word (ENPE = 1) Erase (ENPE = 1) | $I_{\text {FPE }}$ | — | $\begin{gathered} 15 \\ 50 \\ 15 \\ 30 \\ 4 \end{gathered}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> mA <br> mA <br> mA |
| 3 | Program Recovery Time | $\mathrm{t}_{\mathrm{pr}}$ | - | 3 | cycles |
| 4 | Program Pulse Width | $\mathrm{pw}_{\mathrm{pp}}$ | 20 | 25 | $\mu \mathrm{A}$ |
| 5 | Number of Program Pulses ${ }^{3}$ | $\mathrm{n}_{\mathrm{pp}}$ | - | 50 | - |
| 6 | Program Margin ${ }^{4}$ | $\mathrm{p}_{\mathrm{m}}$ | 100 | - | \% |
| 7 | Number of Erase Pulses ${ }^{3}$ | $\mathrm{n}_{\mathrm{ep}}$ | - | 5 | - |
| 8 | Erase Pulse Time | $\mathrm{t}_{\text {epk }}$ | - | $\mathrm{t}_{\text {ei }} \times \mathrm{k}$ | ms |
| 9 | Amount to Increment tep | $\mathrm{t}_{\mathrm{ei}}$ | 90 | 110 | ms |
| 10 | Erase Margin | $\mathrm{e}_{\mathrm{m}}$ | - | $\begin{gathered} \mathrm{n}_{\mathrm{ep}} \\ \Sigma \mathrm{t}_{\mathrm{ei}} \times \mathrm{k} \\ \mathrm{k}=1 \end{gathered}$ | ms |
| 11 | Erase Recovery Time | $\mathrm{t}_{\text {er }}$ | 1 | - | ms |
| 12 | Low-Power Stop Recovery Time ${ }^{5}$ | $\mathrm{t}_{\text {sb }}$ | 1 | - | $\mu \mathrm{A}$ |

1. $\mathrm{V}_{\text {FPE }}$ must not be raised to programming voltage while $\mathrm{V}_{\mathrm{DD}}$ is below specified minimum value. $\mathrm{V}_{\mathrm{FPE}}$ must not be reduced below minimum specified value while $\mathrm{V}_{\mathrm{DD}}$ is applied.
2. Current parameters apply to each individual EEPROM module.
3. Without margin.
4. At $100 \%$ margin, the number of margin pulses required is the same as the number of pulses used to program the byte or word.
5. Parameter measured from end of write cycle that clears STOP bit in FEEMCR.

Table 87 BEFLASH/Flash EEPROM Module Life

| Num | Parameter | Symbol | Value | Unit |
| :---: | :--- | :---: | :---: | :---: |
| 1 | Program-Erase Endurance $^{1}$ | $\mathrm{e}_{\mathrm{pe}}$ | 100 | cyc |
| 2 | Data Retention $^{2}$ | $\mathrm{r}_{\mathrm{d}}$ | 10 | yr |

1. Number of program-erase cycles ( 1 to 0,0 to 1 ) per bit.
2. Parameter based on accelerated-life testing with standard test pattern.


PROG VOLT ENVELOPE

Figure 45 Programming Voltage Envelope

$V_{\text {FPE }}$ CIRCUIT

Figure $46 \mathrm{~V}_{\text {FPE }}$ Conditioning Circuit

## NOTES

## NOTES

Motorola reserves the right to make changes without further notice to any products herein. Motorola makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Motorola assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters can and do vary in different applications. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Motorola does not convey any license under its patent rights nor the rights of others. Motorola products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Motorola product could create a situation where personal injury or death may occur. Should Buyer purchase or use Motorola products for any such unintended or unauthorized application, Buyer shall indemnify and hold Motorola and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Motorola was negligent regarding the design or manufacture of the part. Motorola and $\triangle$ ( 4 are registered trademarks of Motorola, Inc. Motorola, Inc. is an Equal Opportunity/Affirmative Action Employer.

## How to reach us:

USA/EUROPE: Motorola Literature Distribution;
P.O. Box 20912; Phoenix, Arizona 85036. 1-800-441-2447

MFAX: RMFAX0@email.sps.mot.com - TOUCHTONE (602) 244-6609
INTERNET: http://Design-NET.com
JAPAN: Nippon Motorola Ltd.; Tatsumi-SPD-JLDC, Toshikatsu Otsuki,
6F Seibu-Butsuryu-Center, 3-14-2 Tatsumi Koto-Ku, Tokyo 135, Japan. 03-3521-8315
HONG KONG: Motorola Semiconductors H.K. Ltd.; 8B Tai Ping Industrial Park,
51 Ting Kok Road, Tai Po, N.T., Hong Kong. 852-26629298

